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《21 世纪 计算 机 科学 与 技术 实践 型 教程》 
序 


21 世纪 影响 世界 的 三 大 关键 技术 : 以 计算 机 和 网 络 为 代表 的 信息 技术 ;以 基因 工程 
为 代表 的 生命 科学 和 生物 技术 ;以 纳米 技术 为 代表 的 新 型 材料 技术 。 信 息 技 术 居 三 大 关 
键 技术 之 首 。 国 民 经 济 的 发 展 采取 信息 化 带动 现代 化 的 方针 ,要 求 在 所 有 领域 中 迅速 扒 
广 信息 技术 ,导致 需要 大 量 的 计算 机 科学 与 技术 领域 的 优秀 人 才 。 

计算 机 科学 与 技术 的 广泛 应 用 是 计算 机 学 科 发 展 的 原动力 ,计算 机 科学 是 一 门 应 用 
科学 。 因 此 ,计算 机 学 科 的 优秀 人 才 不 仅 应 具有 坚实 的 科学 理论 基础 ,而 且 更 重要 的 是 能 
将 理论 与 实践 相 结合 ,并 具有 解决 实际 问题 的 能 力 。 培 养 计算 机 科学 与 技术 的 优秀 人 才 
是 社会 的 需要 、 国 民 经 济 发 展 的 需要 。 

制定 科学 的 教学 计划 对 于 培养 计算 机 科学 与 技术 人 才 十 分 重要 ,而 教材 的 选择 是 实 
施 教学 计划 的 一 个 重要 组 成 部 分 《21 世纪 计算 机 科学 与 技术 实践 型 教程 ) 主 要 考虑 了 下 
述 两 方面 。 

一 方面 ,高 等 学 校 的 计算 机 科学 与 技术 专业 的 学 生 , 在 学 习 了 基本 的 必修 课 和 部 分 选 
修 课程 之 后 ,立刻 进行 计算 机 应 用 系统 的 软件 和 硬件 开发 与 应 用 尚 存在 一 些 困难 ,而 (21 世 
纪 计 算 机 科学 与 技术 实践 型 教程 ) 就 是 为 了 填补 这 部 分 空白 。 将 理论 与 实际 联系 起 来 ,使 
学 生 不 仅 学 会 了 计算 机 科学 理论 ,而 且 也 学 会 应 用 这 些 理 论 解决 实际 问题 。 

另 一 方面 ,计算 机 科学 与 技术 专业 的 课程 内 容 需 要 经 过 实践 练习 ,才能 深刻 理解 和 掌握 。 
因此 ,本 套 教材 增强 了 实践 性 ,应 用 性 和 可 理解 性 ,并 在 体例 上 做 了 改进 一 一 使 用 案例 说 明 。 

实践 型 教学 占有 重要 的 位 置 , 不 仅 体现 了 理论 和 实践 紧密 结合 的 学 科 特 征 , 而 且 对 于 提 
高 学 生 的 综合 素质 ,培养 学 生 的 创新 精神 与 实践 能 力 有 特殊 的 作用 。 因 此 ,研究 和 撰写 实践 
型 教材 是 必需 的 ,也 是 十 分 重要 的 任务 。 优 秀 的 教材 是 保证 高 水 平 教学 的 重要 因素 ,选择 水 
平 高 .内 容 新 、 实 践 性 强 的 教材 可 以 促进 课堂 教学 质量 的 快速 提升 。 在 教学 中 ,应 用 实践 型 
教材 可 以 增强 学 生 的 认 知 能 力 .创新 能 力 ,实践 能 力 以 及 团队 协作 和 交流 表达 能 力 。 

实践 型 教材 应 由 教学 经 验 丰富 ,实际 应 用 经 验 丰富 的 教师 撰写 。 此 系列 教材 的 作者 
不 但 从 事 多 年 的 计算 机 教学 ,而且 参加 并 完成 了 多 项 计算 机 类 的 科研 项 目 ,他 们 把 积累 的 
经 验 、 知 识 ,智慧 ,素质 融合 于 教材 中 .奉献 给 计算 机 科学 与 技术 的 教学 。 

我 们 在 组 织 本 系列 教材 过 程 中 ,虽然 经 过 了 详细 的 思考 和 讨论 ,但 毕竟 是 初步 的 尝 
试 ,不 完善 甚至 缺陷 不 可 避免 ,和 敬 请 读者 指正 。 


本 系列 教材 主编 陈 明 
2005 年 1 月 于 北京 
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网 站 开发 在 企业 、 组 织 和 个 人 方面 都 有 广泛 应 用 。 本 书 是 计算 机 网 站 建设 的 教程 , 较 
详细 地 介绍 了 网 站 创建 的 全 过 程 ,主要 内 容 包 括 网 站 设计 基础 .HTML、 CSS 和 
JavaScript 基础 .ASP. NET 基础 ,数据库 基础 与 ADO. NET .远程 教育 系统 实例 、Web 服 
务 器 和 数据 库 服 务 器 、 网 站 安全 和 维护 等 。 

在 网 站 设计 基础 中 ,主要 介绍 了 网 站 的 相关 知识 、 网 站 的 规划 和 网 站 的 设计 等 。 

在 HTML、CSS 和 JavaScript 基础 中 ,主要 介绍 了 HTML 语言 .CSS 层 县 样式 表 和 
JavaScript 语言 简介 等 。 

在 ASP. NET 基础 中 ,主要 介绍 了 Visual Studio. NET 2005、C# 基 础 .ASP. NET 控 
件 和 ASP. NET 基本 对 象 等 。 

在 数据 库 基础 与 ADO. NET 中 ,主要 介绍 了 数据 库 基础 .ADO. NET 模型 简介 和 
ADO. NET 组 件 等 。 

在 远程 教育 系统 实例 中 ,主要 介绍 了 系统 规划 与 设计 、 数 据 库 设计 、 逻 辑 分 层 和 功能 
模块 介绍 等 。 

在 Web 服务 器 和 数据 库 服 务 器 中 ,主要 介绍 了 IIS 配置 与 管理 .SQL Server 2000 的 
配置 与 管理 ,发 布 站 点 等 。 

在 网 站 安全 和 维护 中 ,主要 介绍 了 网 站 安全 、 网 站 的 维护 等 。 

学 完 本 书 , 学 生 能 够 广泛 地 掌握 网 站 的 基础 知识 和 开发 网 站 的 方法 。 

本 书 的 主要 特点 如 下 。 

(1) 内 容 丰 富 而 广泛 。 

(2) 注重 系统 性 和 科学 性 ,突出 了 实用 性 。 

(3) 强调 培养 网 站 建设 的 实践 能 力 。 

(4) 在 编写 形式 上 ,力求 深入 浅 出 、 图 文 并 茂 .语言 精炼 。 

由 于 作者 水 平 有 限 , 书 中 不 足 之 处 在 所 难免 , 敬 请 读者 批评 指正 。 


编 者 
2008 年 6 月 
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第 1 章 网 站 设计 基础 


本 章 主要 讲述 网 站 设计 中 必须 具备 的 相关 知识 及 网 站 的 规划 与 设计 。 通 过 本 章 的 学 
习 , 读 者 可 以 了 解 网 站 的 规划 、 网 站 设计 的 基本 思路 及 网 站 的 设计 技巧 等 相关 知识 。 


1.1 网 站 的 相关 知识 


随 着 网 络 技术 的 不 断 发 展 ,网 络 应 用 已 经 渗透 到 人 类 社会 的 各 个 角落 。 网 站 不 仅 是 
网 络 世界 的 支撑 点 ,更 是 人 们 关注 的 热点 : 政府 利用 网 站 宣传 自己 的 施政 纲领 ,网 络 已 成 
为 政府 与 百姓 交流 的 直通 车 ;企业 利用 网 站 宣传 自己 的 形象 ,挖掘 无 限 商 机 ;个 人 利用 网 
站 展示 个 性 风采 ,创建 彼此 沟通 的 桥梁 。 


1.1.1 初 识 网 站 


网 站 是 基于 Internet 的 ,占用 一 定 磁盘 空间 并 提供 信息 和 服务 的 网 络 站 点 ,通过 网 页 
的 形式 表现 ,由 URL(Uniform Resource Location) 格 式 表 示 。 网 站 可 被 用 来 发 布 信息 、 
宣传 企业 和 开展 电子 商务 等 。 

一 般 建设 网 站 有 如 下 4 个 目的 。 

(1) 信息 发 布 及 塑造 企业 形象 。 通 过 Internet, 可 发 布 企业 的 产品 及 服务 信息 ,宣传 
展示 企业 ,塑造 企业 形象 。 

(2) 从 事 商 务 活动 。 建 设 网 站 ,以 Internet 为 媒体 .充分 利用 其 上 的 客户 群 和 通信 作 
用 进行 商务 活动 。 

(3) 吸引 投资 。 根 据 所 建 网 站 拥有 的 价值 出 售 站 点 。 

(4) 兴趣 和 爱好 。 主 要 是 一 些 个 人 ,因为 个 人 爱好 而 建设 网 站 。 


1.1.2 网 站 的 分 类 


网 站 可 以 从 专业 角度 和 内 容 角 度 进行 分 类 。 

从 专业 角度 可 将 网 站 分 为 专业 型 网 站 和 个 人 网 站 。 

(1) 专业 型 网 站 : 由 公司 企业、 政府 机 构 和 社会 团体 等 经 营 的 专业 网 站 。 这 类 网 站 
含金量 高 ,能 够 提供 多 种 服务 ,具有 很 高 的 经 济 和 社会 价值 。 

(2) 个 人 网 站 : 个 人 建立 ,以 展示 自我 .介绍 自身 兴趣 、 爱 好 和 专长 为 主要 目的 的 小 
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型 网 站 。 
从 内 容 角度 上 ,网 站 大 致 可 分 为 以 下 几 类 。 
(1) 娱乐 与 休闲 类 : 如 聊天 、 论 坛 .棋牌 和 交友 等 。 
(2) 文学 与 艺术 类 : 如 网 络 文学 诗歌 .纪实 传记 、 文 学 期 刊 和 小 说 等 。 
(3) 计算 机 与 Internet 类 : 如 软 硬 件 .Internet 电子 商务 和 网 页 制作 等 。 
(4) 体育 与 游戏 类 : 如 球 类 运动 .健身 与 健美 .养生 和 计算 机 游戏 等 。 
(5) 工商 经 济 类 : 如 金融 投资 、 股 市、 经济 热 点 .房地产 和 会 议 展览 等 。 
(6) 公司 企业 类 : 如 国外 公司 企业 、 国 内 上 市 公司 ,机 械 \, 电 子 电 气 和 服装 鞋 帽 等 。 
(7) 新 闻 与 媒体 类 : 如 报纸 、 杂 志 、 电 视 、 新 闻 网 站 和 时 事 论坛 等 。 
(8) 教育 与 科技 类 : 如 留学 与 移民 考试 与 人 学 .远程 教育 .语言 教育 和 高 等 教育 等 。 


1.1.3 主页 与 网 页 


主页 和 网 页 是 两 个 容易 混淆 的 概念 。 网 页 泛 指 WWW 上 所 有 可 供 浏 览 的 页 面 ;而 主 
页 特 指 用 户 进入 网 站 后 所 看 到 的 第 一 个 页 面 。 当 用 户 在 浏览 器 的 地 址 栏 中 输入 网 站 的 
URL 地 址 后 ,浏览 器 就 会 自动 链接 到 这 个 网 址 所 指向 的 Web 服务 器 ,打开 一 个 默认 的 网 
页 作为 网 站 的 开始 。 因 此 这 个 总 是 被 最 先 打开 的 默认 页 面 称 为 “主页 "或 “首页 ”。 
主页 是 用 户 登录 网 站 后 首先 看 到 的 页 面 , 所 以 主页 的 设计 至 关 重 要 。 主 页 应 该 亮丽 
美观 .表现 出 网 站 的 风格 .内容 ,吸引 用 户 的 注意 力 ,否则 很 难 给 用 户 留 下 深刻 的 印象 。 


1.1.4 网 页 的 组 成 元 素 


构成 网 页 的 主要 元 素 有 文字 、 图 像 和 超级 链接 。 文 字 和 图 像 是 向 用 户 传导 信息 的 媒 
介 , 而 超级 链接 则 是 链接 不 同 页 面 的 纽带 ,三 部 分 有 机 结合 .组 成 了 完整 的 页 面 。 随 着 网 
络 技术 的 发 展 ,人 们 不 再 满足 于 简单 的 静态 内 容 , 于 是 各 种 多 媒体 元 素 也 被 加 入 到 网 页 
中 ,如 声音 ,视频 图 画 等 。 

LT 实 尘 

文字 是 页 面 传导 信息 的 主体 ,页 面 上 的 大 部 分 内 容 都 是 用 文字 表现 的 。 文 字 所 占 的 
空间 非常 小 ,因此 下 载 速度 很 快 。 网 页 上 的 文字 可 以 有 不 同 的 大 小 、 文 体 、 颜 色 和 格式 ,从 
而 使 网 页 看 起 来 生动 活泼 。 如 果 采 用 一 些 动态 技术 ,就 可 以 使 文字 具有 各 种 各 样 的 动态 
效果 。 

2. 图 像 

图 像 是 网 页 设计 必 不 可 少 的 另 一 个 要 素 , 它 能 给 用 户 带 来 更 为 强烈 的 视觉 效果 。 图 
像 不 但 可 以 直观 表达 信息 ,还 可 以 起 装饰 和 美化 网 页 的 作用 。 在 页 面 中 经 常 使 用 的 图 像 
格式 有 GIF 和 JPEG 两 种 。 

(1) GIF 图 像 。GIF(Graphics Interchange Format) 是 网 页 中 最 常用 的 图 像 格 式 。 它 
采用 无 损 压 缩 方式 ,图 像 没 有 细节 上 的 损失 ,并 且 解 压 打 开 速 度 非常 快 。GIF 图 像 支 持 透 
明 背 景 ,能 够 和 网 页 结合 成 为 一 个 整体 ,视觉 效果 非常 协调 。 另 外 ,GIF 图 像 还 支持 动态 
效果 ,通过 专门 软件 ,如 GIF ANIMATOR 就 可 以 做 出 动态 的 GIF 图 像 ,使 网 页 效果 更 为 
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生动 。 但 是 GIF 图 像 只 支持 256 种 颜色 ,所 以 不 适合 对 颜色 质量 要 求 高 的 场合 ,如 昭 
片 等 。 

(2) JPEG 图 像 。JPEG(Joint Photographic Expert Group) 格 式 使 用 先进 的 压缩 算 
法 ,使 文件 比 GIF 图 像 文 件 小 ,因而 下 载 速度 快 。JPEG 支持 高 达 1670 万 种 颜色 ,非常 适 
合 存储 颜色 丰富 的 画面 ,如 风景 画 、 照 片 等 。 

3. 超级 链接 

超级 链接 是 WWW 中 最 具 特 色 的 功能 。 为 了 在 网 页 之 间 自 由 跳 转 ,可 以 在 网 页 上 的 
文字 或 图 像 中 加 入 目标 网 页 或 网 站 的 URL 地 址 ,这 就 生成 了 一 个 超级 链接 。 当 用 户 在 
浏览 网 页 时 ,鼠标 经 过 超级 链接 时 ,就 会 变 成 小 手 状态 ,这 时 单 击 , 浏 览 器 就 会 打开 超级 链 
接 所 指 的 页 面 。 超 级 链接 使 页 面 与 页 面 、 网 站 与 网 站 之 间 链 接 成 一 个 整体 ,用 户 可 以 用 鼠 
标 自由 找到 自己 想 要 浏览 的 网 页 。 

4. 多 媒体 元 素 

网 页 上 的 多 媒体 元 素 通 常 可 以 分 为 音频 和 动画 两 种 ,网 页 上 常用 的 音频 文件 有 
WAV 和 MIDI 格式 ;动画 文件 的 格式 有 AVI 视频 Java Applet 动画 等 。 还 有 一 些 多 媒 
体 文件 ,需要 浏览 器 安装 执行 插件 才 可 以 运行 ,如 Flash .Generator 和 Shockwave 等 生成 
的 文件 。 


1.2 网 站 的 规划 


要 开发 一 个 优秀 的 网 站 ,通常 应 该 遵循 以 下 工作 流程 : 确定 开发 网 站 的 目的 ;对 网 站 
的 外 观 进 行 设计 ;对 实际 页 面 进行 制作 ;对 所 做 网 站 进行 测试 ,以 确保 它 符合 最 初 设计 的 
目标 ;发 布 网 站 。 网 站 发 布 后 还 需要 对 网 站 进行 维护 ,以 便 及 时 更 新 网 站 内 容 。 

良好 的 规划 是 进一步 工作 的 基础 ,在 网 站 建设 开始 时 ,对 网 站 进行 详细 设计 规划 和 组 
织 会 大 大 方便 以 后 的 工作 。 网 站 的 规划 通常 包括 以 下 内 容 。 

1. 确定 建立 网 站 的 目标 

确定 建立 网 站 的 目标 至 关 重 要 ,如 确定 建立 网 站 是 为 了 销售 产品 还 是 为 了 做 服务 ; 确 
定 网 站 的 对 象 ;确定 网 站 所 提供 的 信息 和 服务 等 。 

2. 确定 网 站 的 类 型 

目前 网 站 有 以 下 几 种 类 型 。 

(1) 信息 : 全 国 性 媒体 、 地 方 性 媒体 、 商 业 信息 和 地 方 信息 。 

(2) 组 织 : 法 律 法 规 数据 库 教育 站 点 。 

(3) 专题 : 旅游 .财经 、 体 育 、 科 学 和 食品 。 

(4) 个 人 : 个 人 展台 。 

3. 确定 网 站 主题 内 容 

在 这 一 阶段 ,需要 掌握 一 些 典 型 目标 用 户 的 基本 信息 。 例 如 ,他 们 共同 的 兴趣 是 什 
么 ? 他 们 希望 从 站 点 中 获得 什么 ?要 获得 这 些 信 息 , 既 可 以 做 一 些 问 卷 调查 ,也 可 以 从 亲 
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友 、 同 学 那里 得 到 一 些 建议 。 甚 至 可 以 先 将 网 站 发 布 , 在 站 点 中 设立 信息 页 ,从 浏览 者 那 
里 得 到 实际 的 信息 ,然后 再 对 网 站 进行 改进 。 

4. 确定 网 站 风格 

确定 网 站 的 整体 风格 .也 就 决定 了 网 站 内 容 的 表现 形式 ,包括 网 页 所 采用 的 布局 结 
构 .颜色 .字体 .标志 图 形 和 图 像 等 。 不 管 采用 什么 样 的 风格 ,只 要 能 够 找到 文字 与 图 像 及 
其 他 网 络 媒体 的 平衡 点 ,给 访问 者 提供 需要 的 信息 ,最 终 吸 引 访问 者 ,那么 网 站 就 是 成 
功 的 。 

Internet 上 的 网 站 风格 繁多 ,归纳 起 来 主要 有 以 下 两 种 。 

(1) 信息 式 : 这 类 网 站 主要 以 文字 信息 为 主 ,所 以 页 面 的 布局 要 求 整齐 划一 ,而 且 网 
站 中 每 个 层次 页 面 都 会 有 一 个 导航 系统 ,顶部 区 域 大 多 使 用 一 些 比较 有 特色 的 徽标 或 公 
司 的 商标 ,顶部 中 间 是 一 些 广告 横幅 ,页 面 剩余 部 分 则 分 门 别 类 地 放置 了 大 量 的 文本 超级 
链接 。 整 个 站 点 对 图 像 .动画 等 这 些 带 有 修饰 成 分 的 多 媒体 信息 采用 比较 低调 的 处 理 ,每 
个 页 面 仅仅 包含 少量 图 片 或 GIF 动画 。 目 前 国内 知名 的 门户 网 站 ,如 “新 浪 ”"、“ 搜 狐 ” 和 
“网 易 " 等 都 属于 信息 式 的 网 站 。 

(2) 面 廊 式 : 这 类 站 点 的 典型 代表 是 个 人 网 站 或 公司 网 站 ,表现 形式 主要 以 图 像 . 动 
面 和 多 媒体 等 高 新 网 络 技术 为 主 , 注 重 通过 各 种 信息 手段 表现 个 人 特色 或 公司 要 宣扬 的 
理念 。 

5. 确定 网 页 系统 树 

系统 性 对 任何 一 项 工作 都 相当 重要 ,构建 一 个 内 容 繁 多 的 公司 网 站 绝 不 能 像 构 建 个 
人 网 站 那样 随意 增删 内 容 , 应 该 利用 系统 树 对 网 页 进行 规划 、 设 计 和 维护 。 

6. 确定 网 页 内 容 

在 这 里 ,网 页 内 容 并 非 指 网 站 内 容 , 不 是 说 网 页 中 要 包含 广告 .产品 信息 和 服务 等 内 
容 , 而 是 要 具体 细 化 到 每 个 页 面 。 

7. 定制 数据 库 

数据 库 对 于 任何 一 个 网 络 公司 来 说 是 必须 具备 的 ,具体 可 含 产品 数据 库 、 客 户 数 据 
库 、 反 馈 信息 数据 库 及 竞争 对 手数 据 库 等 。 

8. 考虑 网 络 的 技术 问题 

在 设计 网 页 时 要 充分 考虑 网 络 带宽 问题 ,另外 还 要 考虑 浏览 器 、 分 辩 率 及 相应 的 搬 
件 等 。 


1.3 网 站 的 设计 


1.3.1 网 站 设计 的 基本 思路 


1. 定位 网 站 的 主题 和 名 称 
网 站 的 主题 也 就 是 网 站 的 题材 , 它 是 网 站 设计 时 首先 遇 到 的 问题 。 网 站 题材 千 奇 百 
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怪 ,琳琅 满目 ,只 要 想得到 ,就 可 以 把 它 制作 出 来 。 定 位 网 站 遵循 的 原则 如 下 。 

1) 主题 要 小 而 精 

定位 要 小 ,内 容 要 精 。 如 果 制 作 一 个 包罗 万 象 的 站 点 ,把 所 有 人 们 认为 精彩 的 东西 都 
放 在 上 面 ,那么 往往 会 事与愿违 ,因为 它 给 人 的 感觉 是 没有 主题 ,没有 特色 ,虽然 样 样 有 ， 
却 样 样 都 很 肤浅 ,因为 人 们 不 可 能 有 那么 多 的 精力 去 维护 它 。 网 站 的 最 大 特点 就 是 新 和 
快 ,目前 最 热门 的 个 人 主页 都 是 天 天 更 新 甚至 几 小 时 更 新 一 次 。 最 新 的 调查 结果 也 显示 ， 
网 络 上 的 “主题 站 ” 比 “万 全 站 ”更 受 人 们 喜爱 ,就 好 比 专卖 店 和 百货 商店 ,如 果 我 需要 买 某 
一 方面 的 东西 ,肯定 会 选择 专卖 店 。 

2) 题材 最 好 是 自己 擅长 或 者 喜爱 的 内 容 

兴趣 是 制作 网 站 的 动力 ,没有 热情 ,很 难 设计 制作 出 优秀 的 网 站 。 例 如 ,擅长 编程 ,就 
可 以 建立 一 个 编程 爱好 者 网 站 ;对 足球 感 兴趣 ,可 以 报道 最 新 的 战况 、 球 星 动态 等 。 这 样 
在 制作 时 , 才 不 会 觉得 无 聊 或 者 力不从心 。 

3) 题材 不 要 太 滥 或 者 目标 太 高 

“ 太 滥 ”是 指 到 处 可 见 , 人 人 都 有 的 题材 ,如 软件 下 载 . 免 费 信 息 。“ 目 标 太 高 ”是 指 在 
这 一 题材 上 已 经 有 非常 优秀 和 知名 度 很 高 的 站 点 ,要 超过 它 是 很 困难 的 。 

2. 定位 网 站 的 CI 形象 

CICCorporate Identity) 是 指 通 过 视觉 来 统一 企业 的 形象 。 一 个 杰出 的 网 站 ,和 实体 
公司 一 样 ,需要 整体 的 形象 包装 和 设计 。 准 确 的 有 创意 的 CI 设计 ,对 网 站 的 宣传 推广 有 
事半功倍 的 效果 。 具 体 的 做 法 如 下 。 

1) 设计 网 站 的 标志 (logo) 

就 如 同 商品 的 商标 一 样 , 网 站 标志 是 站 点 特色 和 内 涵 的 集中 体现 。 标 志 的 设计 创意 
来 自 网 站 的 名 称 和 内 容 。 

网 站 有 代表 性 的 人 物 ,动物 和 花草 等 ,可 以 用 它们 作为 设计 的 蓝本 ,加 以 卡通 化 和 艺 
术 化 ,例如 迪斯尼 的 米 老 鼠 、 搜 狐 的 卡通 狐狸 等 。 

网 站 有 专业 性 的 ,可 以 以 本 专业 有 代表 的 物品 作为 标志 。 例 如 ,中 国 银行 的 铜板 标 
志 、 奔 驰 汽车 的 方向 盘 标志 等 。 

最 常用 和 最 简单 的 方式 是 用 自己 网 站 的 英文 名 称 作 标志 。 采 用 不 同 的 字体 .字母 的 
变形 和 字母 的 组 合 可 以 很 容易 制作 好 自己 的 标志 。 

2) 设计 网 站 的 标准 色彩 

网 站 给 人 的 第 一 印象 来 自视 觉 冲击 ,确定 网 站 的 标准 色彩 是 相当 重要 的 一 步 。 不 同 
的 色彩 搭配 产生 不 同 的 效果 ,并 可 能 影响 到 访问 者 的 情绪 。 举 个 实际 的 例子 就 明白 了 : 
IBM 的 深蓝 色 、 肯 德 基 的 红色 条 型 、Windows 视窗 标志 上 的 红 蓝 黄 绿色 块 ,都 使 我 们 觉得 
很 贴切 、 很 和 谐 .。“ 标 准 色彩 ?是 指 能 体现 网 站 形象 和 延伸 内 涵 的 色彩 。 一 般 来 说 ,一 个 网 
站 的 标准 色彩 不 超过 三 种 , 太 多 则 让 人 眼花 绕 乱 。 标 准 色彩 要 用 于 网 站 的 标志 、 标 题 、 主 
菜单 和 主 色 块 , 它 给 人 以 整体 统一 的 感觉 。 至 于 其 他 色彩 也 可 以 使 用 ,只 是 作为 点 级 和 衬 
托 , 绝 不 能 喧 宾 夺 主 。 适 合 于 网 页 标准 色 的 颜色 有 蓝 色 、 黄 / 杰 色 及 黑 / 灰 /白色 三 大 系列 
色 , 要 注意 色彩 的 合理 搭配 。 
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3) 设计 网 站 的 标准 字体 

和 标准 色彩 一 样 , 标 准 字体 是 指 用 于 网 站 的 标志 、 标 题 和 主 莱 单 的 特有 字体 。 一 般 网 
页 默认 的 字体 是 宋体 。 为 了 体现 站 点 的 “与 众 不 同 ” 和 特有 风格 ,可 以 根据 需要 选择 一 些 
特别 字体 。 例 如 ,为 了 体现 专业 可 以 使 用 粗 仿宋 体 ,体现 设计 精美 可 以 用 广告 体 ,体现 亲 
切 随意 可 以 用 手写 体 等 。 

4) 设计 网 站 的 宣传 标语 

网 站 的 标语 是 网 站 的 精神 和 目标 。 它 是 用 一 句 话 甚至 一 个 词 来 高 度 概括 。 

3. 确定 网 站 的 栏目 

建立 一 个 网 站 好 比 写 一 篇 文章 ,首先 要 拟 好 提纲 ,文章 才能 主题 明确 .层次 清晰 。 如 
果 网 站 结构 不 清晰 .目录 庞杂 和 内 容 东 一 块 西 一 块 , 结 果 不 但 浏览 者 看 得 糊涂 ,自己 扩充 
和 维护 网 站 也 相当 困难 。 网 站 的 题材 确定 后 ,并 且 收 集 和 组 织 了 许多 相关 的 资料 内 容 , 但 
如 何 组 织 内 容 才 能 吸引 人 们 浏览 网 站 呢 ? 栏目 的 实质 是 一 个 网 站 的 大 纲 索引 ,索引 应 该 
将 网 站 的 主体 明确 显示 出 来 。 一 般 的 网 站 栏目 安排 要 注意 以 下 几 方 面 。 

1) 要 紧 扣 主 题 

将 主题 按 一 定 的 方法 分 类 并 将 它们 作为 网 站 的 主 栏目 。 主 题 栏目 个 数 在 总 栏目 中 要 
占 绝对 优势 ,这 样 的 网 站 比较 专业 ,主题 突出 ,容易 给 人 留 下 深刻 印象 。 

2) 设立 最 近 更 新 或 网 站 指南 栏目 

设立 “最 近 更 新 ”的 栏目 ,是 为 了 照顾 常 来 的 访客 ,让 主页 更 有 人 性 化 。 如 果 主 页 内 容 
庞大 ,层次 较 多 ,而 又 没有 站 内 的 搜索 引擎 ,设置 “本 站 指南 ”栏目 ,可 以 帮助 初 访 者 快速 地 
找到 他 们 想 要 的 内 容 。 

3) 设立 可 以 双向 交流 的 栏目 

如 论坛 .留言 本 和 邮件 列表 等 ,可 以 让 浏览 者 留 下 他 们 的 信息 。 

4) 设立 下 载 或 常见 问题 回答 栏目 

网 络 的 特点 是 信息 共享 ,如 在 主页 上 设置 一 个 资料 下 载 栏目 ,便于 访问 者 下 载 所 需 资 
料 。 另 外 ,如 果 站 点 经 常 收 到 网 友 关 于 某 方面 的 问题 来 信 , 最 好 设立 一 个 常见 问题 回答 的 
栏目 , 既 方便 了 网 友 , 又 可 以 节省 自己 更 多 的 时 间 。 

4. 确定 网 站 的 目录 结构 

网 站 的 目录 是 指 建立 网 站 时 创建 的 目录 。 目 录 结 构 的 好 坏 , 对 浏览 者 来 说 并 没有 什 
么 太 大 的 感觉 ,但 是 对 于 站 点 本 身 的 上 传 维护 、 未 来 的 扩充 和 移植 有 着 重要 的 影响 。 下 面 
是 建立 目录 结构 的 一 些 建议 。 

(1) 不 要 将 所 有 文件 都 存放 在 根 目录 下 ,否则 会 造成 文件 管理 混乱 。 

所 有 文件 都 存放 在 根 目录 下 ,会 使 用 户 常常 搞 不 清 哪些 文件 需要 编辑 和 更 新 ,哪些 无 
用 的 文件 可 以 删除 .哪些 是 相关 联 的 文件 ,从 而 影响 工作 效率 。 另 外 ,上 传 速度 慢 。 服 务 
器 一 般 都 会 为 根 目录 建立 一 个 文件 索引 。 当 将 所 有 文件 都 放 在 根 目录 下 ,那么 即使 只 上 
传 更 新 一 个 文件 ,服务 器 也 需要 将 所 有 文件 再 检索 一 遍 , 建 立新 的 索引 文件 。 很 明显 , 文 
件 量 越 大 ,等 待 的 时 间 也 将 越 长 。 因 此 ,要 尽 可 能 地 减少 根 目 录 的 文件 存放 数 。 
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(2) 按 栏目 内 容 建立 子 目录 。 

子 目录 的 建立 ,首先 按 主 菜单 栏目 建立 。 例 如 ,企业 站 点 可 以 按 公 司 简介 、 产 品 介绍 、 
价格 \ 在 线 订单 和 反馈 联系 等 建立 相应 目录 。 其 他 的 次 要 栏目 .类 似 what”s new ,友情 链 
接 内 容 较 多 ,需要 经 常 更 新 的 可 以 建立 独立 的 子 目录 。 而 一 些 相 关 性 强 , 不 需要 经 常 更 新 
的 栏目 ,如 关于 本 站 、 关 于 站 长 和 站 点 经 历 等 可 以 合并 放 在 一 个 统一 目录 下 。 所 有 程序 一 
般 都 存放 在 特定 目录 。 例 如 ,CGI 程序 放 在 cgi-bin 目录 。 所 有 需要 下 载 的 内 容 也 最 好 放 
在 一 个 目录 下 。 

(3) 在 每 个 主 栏目 目录 下 都 建立 独立 的 images 目录 。 

为 每 个 主 栏目 建立 一 个 独立 的 images 目录 是 最 方便 管理 的 。 而 根 目录 下 的 images 
目录 只 是 用 来 放 首 页 和 一 些 次 要 栏目 的 图 片 。 

(4) 目录 的 层次 不 要 太 深 。 

目录 的 层次 建议 不 要 超过 三 层 , 维 护 管理 方便 。 

(5) 不 要 使 用 中 文 目录 。 

(6) 不 要 使 用 过 长 的 目录 。 

5. 确定 网 站 的 链接 结构 

网 站 的 链接 结构 是 指 页 面 之 间 相互 链接 的 拓扑 结构 。 它 建立 在 目录 结构 基础 之 上 ， 
但 可 以 跨越 目录 。 建 立 网 站 的 链接 结构 有 两 种 基本 方式 。 

1) 树 状 链接 结构 

类 似 DOS 的 目录 结构 ,首页 链接 指向 一 级 页 面 ,一 级 页 面 链 接 指向 二 级 页 面 。 这 样 
的 链接 结构 浏览 时 ,一 级 级 进入 ,一 级 级 退出 。 优 点 是 条 理 清晰 ,访问 者 明确 知道 自己 在 
什么 位 置 ,不 会 “ 迷 ? 路 。 缺 点 是 浏览 效率 低 ,一 个 栏目 下 的 子 页 面 到 另 一 个 栏目 下 的 子 页 
面 , 必 须 绕 经 首页 。 

2) 星 状 链接 结构 

类 似 网 络 服务 器 的 链接 ,每 个 页 面相 互 之 间 都 建立 有 和 链接。 这 种 链接 结构 的 优点 是 
浏览 方便 ,随时 可 以 到 达 自 己 喜 欢 的 页 面 ;缺点 是 链接 太 多 ,容易 使 浏览 者 迷路 , 搞 不 清 自 
己 在 什么 位 置 和 看 了 多 少 内 容 。 

这 两 种 基本 结构 都 只 是 理想 方式 ,在 实际 的 网 站 设计 中 ,总 是 将 这 两 种 结构 混合 起 来 
使 用 ,达到 比较 理想 的 效果 。 比 较 好 的 方案 是 ,首页 和 一 级 页 面 之 间 用 星 状 链接 结构 ,一 
级 和 以 下 各 级 页 面 之 间 用 树 状 链接 结构 。 

6. 设计 网 站 的 整体 风格 

风格 (style) 是 抽象 的 ,是 指 站 点 的 整体 形象 给 浏览 者 的 综合 感受 。 这 个 “整体 形象 ” 
包括 站 点 的 CI( 标 志 、 色 彩 , 字 体 和 标语 ) ,版面 布局 ,浏览 方式 、 交 互 性 ,文字 语气、 内容 
价值 .存在 意义 和 站 点 荣誉 等 诸多 因素 。 例 如 网 易 是 平易 近 人 的 ,迪斯尼 是 生动 活泼 的 ， 
IBM 是 专业 严肃 的 ,这 些 都 是 网 站 给 人 们 留 下 的 不 同感 受 。 

风格 是 独特 的 ,是 站 点 不 同 于 其 他 网 站 的 地 方 。 或 者 色彩 ,或 者 技术 ,或 者 是 交互 方 
式 , 能 让 浏览 者 明确 分 辨 出 这 是 网 站 独 有 的 。 例 如 新 世纪 网 络 的 黑白 色 , 网 易 壁 纸 站 的 特 
有 框架 ,即使 只 看 到 其 中 一 页 ,也 可 以 分 辨 出 是 哪个 网 站 的 。 
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风格 是 有 人 性 的 。 通 过 网 站 的 外 表 、 内 容 、 文 字 和 交流 可 以 概括 出 一 个 站 点 的 个 性 和 
情绪 。 它 是 温文 颂 雅 ,是 执著 热情 ,是 活泼 易 变 .是 放任 不 里 ,就 像 诗 词 中 的 “豪放 派 "? 和 “ 婉 
约 派 ”, 则 可 以 用 人 的 性 格 来 比喻 站 点 。 如 何 树立 网 站 风格 呢 ? 可 以 分 为 以 下 几 个 步 又 。 

(1) 确信 风格 是 建立 在 有 价值 内 容 之 上 。 一 个 网 站 有 风格 而 没有 内 容 , 就 好 比 绣花 
枕头 一 包 草 ;又 好 比 一 个 性 格 傲慢 但 却 目 不 识 丁 的 人 。 因 此 ,首先 必须 保证 内 容 的 质量 和 
价值 性 ,这 是 最 基本 的 。 

(2) 需要 彻底 搞 清楚 希望 站 点 给 人 的 印象 是 什么 。 

(3) 在 明确 网 站 印象 后 ,开始 努力 建立 和 加 强 这 种 印象 。 

经 过 第 二 步 印 象 的 “量化 "后 ,需要 进一步 找 出 其 中 最 有 特色 特点 的 东西 ,就 是 最 能 体 
现 网 站 风格 的 东西 。 并 以 它 作 为 网 站 的 特色 加 以 重点 强化 ,宣传 。 


1.3.2 网 站 设计 技巧 


1. 明确 内 容 

如 果 想 成 为 一 个 网 站 设计 者 ,并 正 想 建 一 个 网 站 的 话 ,首先 应 该 考虑 网 站 的 内 容 , 包 
括 网 站 功能 和 用 户 需 要 。 整 个 设计 都 应 该 围绕 这 些 方面 来 进行 。 

2. 抓 住 用 户 

如 果 用 户 不 能 够 迅速 地 进入 网 站 ,或 操作 不 便捷 ,网 站 设计 就 是 失败 的 。 不 要 让 用 户 
失望 而 转向 对 手 的 网 站 。 

3. 快速 下 载 

没有 什么 比 要 花 很 长 时 间 下 载 页 面 更 糟糕 的 了 。 作 为 一 条 经 验 ,一 个 标准 的 网 页 应 
不 大 于 60KB, 通 过 56K 调制 解 调 器 加 载 花 30s 的 时 间 。 有 的 设计 者 说 网 页 加 载 应 在 
15s 内 。 

4. 网 站 升级 

时 刻 注 意 网 站 的 运行 状况 。 性 能 很 好 的 主机 随 着 访问 人 数 的 增加 ,可 能 会 运行 缓慢 。 
但 为 了 不 失去 访问 者 ,一 定 要 仔细 计划 好 网 站 升级 计划 。 

5. 网 站 地 图 

许多 设计 者 把 他 们 的 网 站 地 图 放 在 网 站 上 ,这 种 做 法 却 是 次 大 于 利 。 绝 大 部 分 的 访 
问 者 上 网 是 寻找 一 些 特别 的 信息 ,他们 对 于 网 站 是 如 何 工 作 的 并 没有 兴趣 。 如 果 觉 得 网 
站 需要 地 图 , 那 很 可 能 是 需要 改进 网 站 导航 和 工具 条 。 

6. 检查 错别字 

好 的 拼写 是 人 们 一 生 中 重要 的 技能 。 但 是 遗憾 的 是 ,许多 设计 者 都 缺少 这 种 技能 。 
确保 拼写 正确 ,并 且 格 外 注意 平常 容易 误 写 的 字 。 

7. 避免 长 文本 页 面 

在 一 个 站 点 上 有 许多 只 有 文本 的 页 面 ,是 令 人 乏味 的 , 且 也 浪费 Web 的 潜力 。 如 果 
网 站 有 大 量 的 基于 文本 的 文档 ,应 当 以 Adobe Acrobat 格式 的 文件 形式 来 放置 ,以 便 访问 
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者 能 离线 阅读 。 

8. 闪烁 让 人 头痛 

通过 使 用 标识 可 以 吸引 访问 者 对 网 站 主页 特殊 部 分 的 注意 ,但 是 这 也 让 访问 者 头痛 。 
如 果 想 使 访问 者 再 次 光顾 该 网 站 就 少 用 此 方法 。 

9. 背景 颜色 

背景 颜色 也 会 产生 一 些 问题 ,可 能 会 使 网 页 难于 阅读 。 应 当 坚 持 使 用 白色 的 背景 和 
黑色 的 文本 ,另外 还 应 当 坚 持 使 用 通用 字体 。 

10. 慎 用 声音 

声音 的 运用 也 应 得 到 警惕 。 内 联 声 音 是 网 页 设计 者 的 另 一 个 禁地 。 因 为 过 多 地 使 用 
声音 会 使 下 载 速度 很 慢 ,同时 并 没有 带 给 浏览 者 多 少 好 处 。 首 次 听 到 鼠标 发 出 声音 可 能 会 
很 有 趣 , 但 是 多 次 以 后 肯定 会 让 人 厌烦 。 使 用 声音 前 ,应 该 仔细 考虑 声音 将 会 带 来 什么 。 


1.3.3 网 页 的 布局 


布局 ,就 是 以 最 适合 浏览 的 方式 将 图 片 和 文字 排放 在 页 面 的 不 同位 置 。 经 常用 到 的 
版 面 布局 形式 如 下 。 

1. 工 结构 布局 

工 结构 ,就 是 指 页 面 顶 部 为 横 条 网 站 标志 十 广告 条 ,下 方 左边 为 主 菜单 , 右边 显示 内 
容 的 布局 。 因 为 菜单 条 背景 较 深 ,整体 效果 类 似 英文 字母 ,所 以 称 为 工 形 布局 。 这 是 
网 页 设计 中 用 得 最 广泛 的 一 种 布局 方式 。 这 种 布局 的 优点 是 页 面 结构 清晰 、 主 次 分 明 。 
它 是 初学 者 最 容易 上 手 的 布局 方法 。 缺 点 是 规矩 呆板 ,如 果 细节 色彩 上 不 注意 ,很 容易 让 
人 “看 之 无 味 ”。 

2.“ 口 " 形 布局 

这 是 一 个 象形 的 说 法 ,就 是 页 面 一 般 上 下 各 有 一 个 广告 条 ,左边 是 主 菜单 ,右边 放 友 
情 链 接 等 ,中 间 是 主要 内 容 。 这 种 布局 的 优点 是 充分 利用 版 面 ,信息 量 大 。 缺 点 是 页 面 拥 
挤 , 不 够 灵活 。 也 有 将 四 边 空 出 ,只 用 中 间 的 窗口 型 设计 ,例如 网 易 壁 纸 站 。 

3.“ 三 " 形 布局 

这 种 布局 多 用 于 国外 站 点 ,国内 用 得 不 多 。 其 特点 是 页 面 上 横向 两 条 色 块 ,将 页 面 整 
体 分 割 为 4 部 分 , 色 块 中 大 多 放 广 告 条 。 

4. 对 称 对 比 布局 

采取 左右 或 者 上 下 对 称 的 布局 ,一 半 深 色 , 一 半 浅 色 , 一 般 用 于 设计 型 站 点 。 它 的 优 
点 是 视觉 冲击 力 强 ,缺点 是 将 两 部 分 有 机 地 结合 比较 困难 。 

5. POP 布局 

POP 引 自 广告 术语 ,就 是 指 页 面 布局 像 一 张 宣传 海报 ,以 一 张 精 美 图 片 作 为 页 面 的 
设计 中 心 。 常 用 于 时 尚 类 站 点 ,如 ELLE. com。 优 点 是 漂亮 吸引 人 ;缺点 是 速度 慢 。 作 
为 版 面 布局 还 是 值得 借鉴 的 。 
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1.3.4 网 页 的 设计 


在 网 页 设计 的 认识 上 ,许多 人 似乎 仍 停留 在 网 页 制作 的 高 度 上 。 认 为 只 要 用 好 了 网 
页 制作 软件 ,就 能 搞 好 网 页 设计 了 。 

其 实 网 页 设计 是 一 个 感性 思考 与 理性 分 析 相 结合 的 复杂 的 过 程 , 它 的 方向 取决 于 设 
计 的 任务 , 它 的 实现 依赖 于 网 页 的 制作 。 正 所 谓 “ 功 夫 在 诗 外 ”, 网 页 设计 中 最 重要 的 东 
西 ,并非 在 软件 的 应 用 上 ,而 是 在 对 网 页 设计 的 理解 及 设计 制作 的 水 平 上 ,在 于 我 们 自身 
的 美感 及 对 页 面 的 把 握 上 。 

1. 设计 的 原则 

设计 是 有 原则 的 ,无 论 使 用 何 种 手法 对 画面 中 的 元 素 进行 组 合 , 都 一 定 要 遵循 5 个 大 
的 原则 : 统一 .连贯 分割 对比 及 和 谐 。 

(1) 统一 : 指 设计 作品 的 整体 性 ,一 致 性 。 设 计 作品 的 整体 效果 是 至 关 重 要 的 ,在 设 
计 中 切 勿 将 各 组 成 部 分 孤立 分 散 ,那样 会 使 画面 呈现 出 一 种 枝 草 纷 杂 的 凌乱 效果 。 

(2) 连贯 : 指 要 注意 页 面 的 相互 关系 。 设 计 中 应 利用 各 组 成 部 分 在 内 容 上 的 内 在 联 
系 和 表现 形式 上 的 相互 呼应 ,并 注意 整个 页 面 设计 风格 的 一 致 性 ,实现 视觉 上 和 心理 上 的 
连贯 ,使 整个 页 面 设计 的 各 个 部 分 极为 融洽 ,犹如 一 气 呵 成 。 

(3) 分 制 : 指 将 页 面 分 成 若干 小 块 , 小 块 之 间 有 视觉 上 的 不 同 , 这 样 可 以 使 观 者 一 目 
了 然 。 在 信息 量 很 多 时 为 使 观 者 能 够 看 清楚 ,就 要 注意 到 将 画面 进行 有 效 的 分 制 。 分 制 
不 仅 是 表现 形式 的 需要 。 换 个 角度 来 讲 ,分 割 也 可 以 被 视 为 对 于 页 面 内 容 的 一 种 分 类 
归纳 。 

(4) 对 比 : 通过 矛盾 和 冲突 ,使 设计 更 加 富有 生气 。 对 比 手法 很 多 ,例如 ,多 与 少 、 曲 
与 直 、 强 与 弱 ,长 与 短 . 粗 与 细 、 朴 与 密 、 虚 与 实 、 主 与 次 `. 黑 与 白 、 动 与 静 、 美 与 丑 、 聚 与 散 
等 。 在 使 用 对 比 的 时 候 应 慎重 ,对 比 过 强 容易 破坏 美感 .影响 统一 。 

(5) 和 谐 : 指 整 个 页 面 符 合 美的 法 则 ,浑然 一 体 。 如 果 一 件 设计 作品 仅仅 是 色彩 、 形 
状 和 线条 等 的 随意 混合 .那么 作品 将 不 但 没有 “生命 感 ”. 而 且 也 根本 无 法 实现 视觉 设计 的 
传达 功能 。 和 谐 不 仅 要 看 结构 形式 ,而 且 要 看 作品 所 形成 的 视觉 效果 能 否 与 人 的 视觉 感 
受 形成 一 种 沟通 ,产生 心灵 的 共鸣 。 这 是 设计 能 和 否 成 功 的 关键 。 

2. 设计 的 任务 

设计 是 一 种 审美 活动 成功 的 设计 作品 一 般 都 很 艺术 化 。 但 艺术 只 是 设计 的 手段 ,而 
并 非 设 计 的 任务 。 设 计 的 任务 是 要 实现 设计 者 的 意图 .而 并 非 创造 美 。 

网 页 设计 的 任务 ,是 指 设计 者 要 表现 的 主题 和 要 实现 的 功能 。 站 点 的 性 质 不 同 , 设 计 
的 任务 也 不 同 。 从 形式 上 ,可 以 将 站 点 分 为 以 下 三 类 。 

(1) 资讯 类 站 点 。 像 新 浪 、 网 易 和 搜狐 等 门户 网 站 。 这 类 站 点 将 为 访问 者 提供 大 量 
的 信息 ,而 且 访 问 量 较 大 。 因 此 需 注意 页 面 的 分 割 、 结 构 的 合理 、 页 面 的 优化 、 界 面 的 亲 和 
等 问题 。 

(2) 资讯 和 形象 相 结合 的 网 站 。 像 一 些 较 大 的 公司 、 国 内 的 高 校 等 。 这 类 网 站 在 设 
计 上 要 求 较 高 , 既 要 保证 资讯 类 网 站 的 上 述 要 求 , 同 时 又 要 突出 企业 .单位 的 形象 。 然 而 
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就 现状 来 看 ,这 类 网 站 有 粗制滥造 的 嫌疑 。 

(3) 形象 类 网 站 。 如 一 些 中 小 型 的 公司 或 单位 。 这 类 网 站 一 般 较 小 ,有 的 则 有 几 页 ， 
需要 实现 的 功能 也 较为 简单 .网 页 设计 的 主要 任务 是 突出 企业 形象 。 这 类 网 站 对 设计 者 
的 美工 水 平 要 求 较 高 。 

当然 ,这 只 是 从 整体 上 来 看 ,具体 情况 还 要 具体 分 析 , 对 不 同 的 站 点 要 区 别 对待 。 最 
重要 的 一 点 , 那 就 是 客户 的 要 求 , 它 也 属于 设计 的 任务 。 

3. 设计 的 实现 

设计 的 实现 可 以 分 为 两 个 部 分 。 第 一 部 分 为 站 点 的 规划 及 草图 的 绘制 ,这 一 部 分 可 
以 在 纸 上 完 成 。 第 二 部 分 为 网 页 的 制作 ,这 一 过 程 是 在 计算 机 上 完成 的 。 

设计 首页 的 第 一 步 是 设计 版 面 布 局 。 可 以 将 网 页 看 作 传 统 的 报纸 杂志 来 编辑 ,这 里 
面 有 文字 、 图 像 乃 至 动画 ,我 们 要 做 的 工作 就 是 以 最 适合 的 方式 将 图 片 和 文字 排放 在 页 面 
的 不 同位 置 。 除 了 要 有 一 台 配 置 不 错 的 计算 机 外 ,软件 也 是 必需 的 。 不 能 简单 地 说 一 个 
软件 的 好 坏 , 只 要 是 设计 者 使 用 起 来 觉得 方便 而 且 能 得 心 应 手 的 ,就 可 以 称 为 好 软件 。 当 
然 , 它 应 该 能 满足 设计 者 的 要 求 。 常 用 的 软件 有 Macromedia 的 Dreamweaver、 Fire- 
works、Flash 以 及 Adobe 的 Photoshop、Imageready 等 。 

接 下 来 要 做 的 就 是 通过 软件 的 使 用 ,将 设计 的 蓝图 变 为 现实 ,最 终 的 集成 一 般 是 在 
Dreamweaver 里 完成 的 。 虽然 在 草图 上 定 出 了 页 面 的 大 体 轮廓 ,但 是 灵感 一 般 都 是 在 制 
作 过 程 中 产生 的 。 设 计 作品 一 定 要 有 创意 ,这 是 最 基本 的 要 求 ,没有 创意 的 设计 是 失 
败 的 。 

4. 色彩 的 运用 

色彩 是 一 种 奇怪 的 东西 , 它 是 美丽 而 丰富 的 .能 唤起 人 类 的 心灵 感知 。 一 般 来 说 , 红 
色 是 火 的 颜色 ,热情 ,奔放 ; 也 是 血 的 颜色 ,可 以 象征 生命 。 黄 色 是 明度 最 高 的 颜色 ,显得 
华丽 、 高 贵 、 明 快 。 绿 色 是 大 自然 草木 的 颜色 ,意味 着 纯 自 然 和 生长 ,象征 安宁 和 平 与 安 
全 ,如 绿色 食品 。 紫 色 是 高 贵 的 象征 ,有 庄重 感 。 白 色 能 给 人 以 纯洁 与 清白 的 感觉 ,表示 
和 平 与 圣洁 。 

颜色 是 光 的 折射 产生 的 , 红 、 黄 、 蓝 是 三 原色 ,其 他 的 色彩 都 可 以 用 这 三 种 色彩 调和 而 
成 。 换 一 种 思路 ,可 以 用 颜色 的 变化 来 表现 光影 效果 ,这 无 疑 将 使 我 们 的 作品 更 贴近 现实 。 

色彩 代表 了 不 同 的 情感 ,有 着 不 同 的 象征 含义 。 这 些 象征 含义 是 人 们 思想 交流 当中 
的 一 个 复杂 问题 , 它 因 人 的 年 龄 ,地域 . 时 代 、 民 族 、 阶 层 、 经 济 地 区 、 工 作 能 力 、 教 育 水 平 、 
风俗 习惯 .宗教 信仰 .生活 环境 和 性 别 差 异 而 有 所 不 同 。 

单纯 的 颜色 并 没有 实际 的 意义 ,和 不 同 的 颜色 搭配 , 它 所 表现 出 来 的 效果 也 不 同 。 例 
如 绿色 和 金黄 淡白 搭配 ,可 以 产生 优雅 .舒适 的 气氛 。 蓝 色 和 白色 混合 ,能 体现 柔顺 、 淡 
雅 和 浪漫 的 气氛 。 红 色 和 黄色 、 金 色 的 搭配 能 泻 染 喜庆 的 气氛 。 设 计 的 任务 不 同 ,配色 方 
案 也 随 之 不 同 。 考 虑 到 网 页 的 适应 性 ,应 尽量 使 用 网 页 安全 色 。 

但 颜色 的 使 用 并 没有 一 定 的 法 则 ,如 果 一 定 要 用 某 个 法 则 去 套 , 效 果 只 会 适得其反 。 
经 验 上 我 们 可 先 确定 一 种 能 表现 主题 的 主体 色 , 然 后 根据 具体 的 需要 ,应 用 颜色 的 近似 和 
对 比 来 完成 整个 页 面 的 配色 方案 。 整 个 页 面 在 视觉 上 应 是 一 个 整体 ,以 达到 和 谐 . 悦 目的 
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视觉 效果 。 

5. 造型 的 组 合 

在 网 页 设计 中 ,主要 通过 视觉 传达 来 表现 主题 。 在 视觉 传达 中 ,造型 是 很 重要 的 一 个 
元 素 。 不 管 是 图 还 是 文字 ,画面 上 的 所 有 元 素 都 可 以 统一 作为 画面 的 基本 构成 要 素 ( 点 、 
线 、 面 ) 来 进行 处 理 。 在 一 幅 成 功 的 作品 里 ,是 需要 点 、 线 、 面 的 共同 组 合 与 搭配 来 构造 整 
个 页 面 的 。 

通常 可 以 使 用 的 组 合 手 法 有 秩序 比例、 均衡 对 称 、 连 续 、 间 隔 、 重 登 、 反 复 、 交 叉 、 节 
奏 .韵律 ,归纳 、 变 异 、 特 写 和 反射 等 ,它们 都 有 各 自 的 特点 。 在 设计 中 应 根据 具体 情况 , 选 
择 最 适合 的 表现 手法 ,这 样 有 利于 主题 的 表现 。 

通过 点 线 、 面 的 组 合 ,可 以 突出 页 面 上 的 重要 元 素 . 突 出 设计 的 主题 ,增强 美感 ,让 观 
者 在 感受 美的 过 程 中 领会 设计 的 主题 ,从 而 实现 设计 的 任务 。 

造型 的 巧妙 运用 不 仅 能 带 来 极 大 的 美感 ,而 且 能 较 好 地 突出 企业 形象 ,能 将 网 页 上 的 
各 种 元 素 有 机 地 组 织 起 来 ,甚至 还 可 以 引导 观 者 的 视线 。 

6. 网 页 的 优化 

在 网 页 设计 中 ,网 页 的 优化 是 较为 重要 的 一 个 环节 。 它 的 成 功 与 否 会 影响 页 面 的 浏 
览 速 度 和 页 面 的 适应 性 ,影响 观 者 对 网 站 的 印象 。 

在 资讯 类 网 站 中 ,文字 是 页 面 中 最 大 的 构成 元 素 , 因 此 字体 的 优化 显得 尤为 重要 。 使 
用 CSS 样式 表 指 定 文字 的 样式 是 必要 的 ,通常 将 字体 指定 为 宋体 ,大 小 指定 为 12px, 颜 色 
要 视 背 景色 而 定 , 原 则 上 以 能 看 清 并 且 与 整个 页 面 搭配 和 谐 为 准 。 在 白色 的 背景 上 ,一 般 
使 用 黑色 ,这 样 不 易 产 生 视 觉 疲劳 ,能 保证 浏览 者 较 长 时 间 地 浏览 网 页 。 

图 片 是 网 页 中 的 重要 元 素 。 图 片 的 优化 可 以 在 保证 浏览 质量 的 前 提 下 将 其 Size 降 
至 最 低 ,这 样 可 以 成 倍 地 提高 网 页 的 下 载 速度 。 利 用 Photoshop 或 Fireworks 可 以 将 图 
片 切 成 小 块 图 片 ,分 别 进行 优化 。 输 出 的 格式 可 以 为 GIF 或 JPEG, 要 视 具体 情况 而 定 。 
一 般 把 有 较为 复杂 颜色 变化 的 小 块 图 片 优化 为 JPEG ,而 把 那 种 只 有 单纯 色 块 的 卡通 画 
式 的 小 块 图 片 优化 为 GIF ,这 是 由 这 两 种 格式 的 特点 决定 的 。 

表格 (Table) 是 页 面 中 的 重要 元 素 , 是 页 面 排版 的 主要 手段 。 可 以 设 定 表格 的 宽度 、 
高 度 ,边框 .背景 色 和 对 齐 方式 等 参数 。 很 多 时 候 , 将 表格 的 边框 设 为 0, 以 此 来 定位 页 面 
中 的 元 素 ,或 者 借 此 确定 页 面 中 各 元 素 的 相对 位 置 。 我 们 知道 ,浏览 器 在 读 取 网 页 HT- 
ML 原 代 码 时 ,是 读 完整 个 Table 才 将 它 显示 出 来 的 。 如 果 一 个 大 表格 中 含有 多 个 子 表 
格 , 必 须 等 大 表格 读 完 , 才 能 将 子 表格 一 起 显示 出 来 。 在 访问 一 些 站 点 时 ,等 待 多 时 无 结 
果 , 单 击 “ 停 止 " 按 钮 却 一 下 显示 出 页 面 就 是 这 个 原因 。 因 此 ,在 设计 页 面 表格 时 ,应 该 尽 
量 避 免 将 所 有 元 素 艇 套 在 一 个 表格 里 ,而 且 表格 嵌 套 层次 尽量 要 少 。 在 使 用 Dreamweaver 
制作 网 页 时 ,会 自动 在 每 一 个 td 内 添加 一 个 空 字符 “&nbsp;”。 如 果 单 元 格 内 没有 填充 其 他 
元 素 , 这 个 空 字符 会 保留 ,在 指定 td 的 宽度 或 高 度 后 ,可 以 在 源 代 码 内 将 其 删 去 。 

网 页 的 适应 性 是 很 重要 的 ,在 不 同 的 系统 .不 同 的 分 辩 率 和 不 同 的 浏览 器 上 ,将 会 看 
到 不 同 的 结果 ,因此 设计 时 要 统筹 考虑 。 一 般 在 800X600 下 制作 网 页 ,最 佳 浏览 效果 也 
是 在 800X600 分 辩 率 下 ,在 其 他 情况 下 只 要 保证 基本 一 致 ,不 出 现 较 大 问题 即 可 。 
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本 章 简要 介绍 构建 网 页 前 台 页 面 的 主要 内 容 一 一 HTML、CSS 和 JavaScript。 通 过 
本 章 的 学 习 , 应 该 对 建设 网 站 的 前 台 脚 本 有 一 定 的 认识 。 能 够 自己 设计 一 些 简 单 的 静态 
网 页 。 

超 文 本 标记 语言 (Hyper Text Mark-up Language,， HTML) 和 一 般 文本 不 同 , 一 个 
HTML 文件 不 仅 包含 文本 内 容 , 还 包含 一 些 Tag, 中 文 称 “ 标 记 ”。 一 个 HTML 文件 的 后 
缀 是 . htm 或 者 是 . html, 用 文本 编辑 器 就 可 以 编写 HTML 文件 。 

JavaScript 是 一 种 新 的 描述 语言 ,此 语言 可 以 被 蔡 入 HTML 的 文件 之 中 。 透 过 
JavaScript 可 以 做 到 回应 使 用 者 的 需求 事件 (如 form 的 输入 ) ,而 不 用 任何 的 网 络 来 回 传 
输 资料 。 所 以 当 一 位 使 用 者 输入 一 项 资料 时 , 它 不 用 经 过 传 给 服务 端 (server) 处 理 , 再 传 
回来 的 过 程 ,而 可 以 直接 被 客户 端 (client) 的 应 用 程序 所 处 理 。 

JavaScript 是 一 种 基于 对 象 和 事件 驱动 并 具有 安全 性 能 的 脚本 语言 。 使 用 它 的 目的 
是 与 HTML、Java 脚本 语言 一 起 实现 在 一 个 网 页 中 链接 多 个 对 象 ,与 网 络 客户 交互 作用 ， 
从 而 可 以 开发 客户 端的 应 用 程序 。 它 是 通过 嵌入 或 调 入 在 标准 的 HTML 语言 中 实现 的 。 

层 琶 样式 表单 (Cascading Style Sheets.CSS) 也 称 作 样 式 表 。 顾 名 思 义 , 它 是 一 种 设 
计 网 页 样式 的 工具 。 利 用 其 属性 可 以 设置 字体 .颜色 和 背景 等 页 面 格式 ;利用 其 定位 可 以 
使 页 面 布局 更 加 规范 .好 看 ;利用 其 滤 镜 可 以 使 页 面 产生 多 媒体 效果 。CSS 的 功能 很 强 
大 ,在 后 面 的 教程 中 将 对 它 进行 详细 的 讲解 。 


2.1 上 TML 语言 
2.1.1 网 页 架构 


<HIML> 
< HEAD> 
<TITLE> 网 页 制作 < /TITLE> 
<Meta>…< /Meta> 
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< /HEAD> 
<BODY> 
BoDY 之 间 则 为 主要 语法 所 在 ,也 是 网 页 的 主要 呈现 部 分 。 
< /BODY> 
< /HIML> 


标签 解说 : 

上 面 是 结构 最 简单 的 网 页 。 网 页 其 实 就 是 标签 (标签 就 是 指 被 二 二 包 起 来 的 语法 ) 的 
集合 , 透 过 浏览 器 的 消化 整理 ,就 变 成 了 网 页 。 

简单 而 言 ,通常 一 份 完整 的 网 页 包含 了 两 个 部 分 : 抬头 (HEAD) 和 文件 本 体 
(BODY) 。 即 上 面 所 看 到 的 <HEAD> 一 /HEAD>> 及 一 BODY 二 一 /BODY> 。 

在 抬头 部 分 HEAD>></HEAD> 中 ,有 另 一 组 标签 <TITLE> 一 /TITLE 之 。 打 
在 二 TITLE></TITLE> 这 里 面 的 文字 会 出 现在 浏览 器 视窗 最 上 头 蓝 色 部 分 里 ,作为 
网 页 的 主题 。 

二 HTML 二 /HTML> 这 组 标签 是 可 有 可 无 的 。 这 组 标签 是 告诉 浏览 器 : 这 是 一 
份 HTML 文件 。 通 常 都 包 在 网 页 的 最 上 下 两 端 ,将 所 有 的 原始 代码 都 包 起 来 。 


2.1.2 分 隔 标签 


1. 文字 上 的 分 隔 标 签 

使 用 方法 : 

强制 断 行 标签 <br> ,强制 分 段 标签 <p> 

标签 解说 : 在 写 文 章 时 ,有 时 在 特定 的 地 方 会 强迫 断 行 (二 br 二 ) ,或 是 在 写 完 某 一 段 
的 时 候 便 会 分 段 (<p 二 ) 。 写 网 页 也 一 样 ,而 且 更 需要 断 行 及 分 段 的 功能 ,使 整个 网 页 整 
齐 美 观 。 

使 用 范例 如 表 2-1 所 示 。 

表 2-1 文字 分 隔 标签 


原始 代码 呈现 结果 
这 是 一 个 断 行 的 范例 <br> 看 出 来 了 吗 ? 这 是 一 个 断 行 的 范例 看 出 来 了 吗 ? 
这 是 一 个 分 段 的 范例 <p> 基 本 上 它 会 比 断 行 还 多 | 这 是 一 个 分 段 的 范例 基本 上 分 段 会 比 断 行 还 多 
空 出 一 行 空 出 一 行 
2. 分 隔 线 标签 
使 用 方法 : 


上 一 段 文字 内 容 <hr> 下 一 段 文字 内 容 

标签 解说 : 利用 二 hr 二 标签 便 可 产生 一 条 横 分 隔 线 。 另 外 , 它 的 部 分 属性 分 别 说 明 
如 下 。 

使 用 范例 如 表 2-2 所 示 。 
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表 2-2 分 隔 线 标签 

一 般 用 法 尚未 加 任何 属性 

原始 代码 普通 分 隔 线 <hr> 

呈现 结果 普通 分 隔 线 

颜色 属性 用 法 : <hr color= "颜色 码 或 颜色 名 称 "> 

原始 代码 橘 色 分 隔 线 <hr color= "# ff8000"> 

呈现 结果 桥 色 分 隔 线 

宽度 属性 用 法 : <hr width= "宽度 "> ,其 单位 为 px( 像 素 ), 宽 度 亦 可 用 百分比 来 作 设 
定 ,如 50% 即 意 为 宽度 占 屏 幕 50% 

原始 代码 宽度 为 240px 的 分 隔 线 <hr width= "240"> 

呈现 结果 宽度 为 240px 的 分 隔 线 

厚度 属性 用 法 : <hr size= "厚度 "> 

原始 代码 厚度 为 5 的 分 隔 线 <hr size= "5"> 

呈现 结果 厚度 为 5 的 分 隔 线 

位 置 属性 用 法 : <hr align= "水 平 对 齐 位 置 "> ,其 设 定 值 有 三 个 ,也 就 是 置 左 align 一 
"left" . 置 中 align 一 "center" 和 置 右 align 一 "right" 

原始 代码 靠 右 的 分 隔 线 <hr align= "right"> 

呈现 结果 靠 右 的 分 隔 线 

阴影 属性 用 法 : <hr noshade> ,无 设 定 值 ,只 要 将 noshade 加 入 即 可 ,通常 会 配合 颜色 
设 定 , 效 果 较 佳 

原始 代码 实心 分 隔 线 (无 阴影 )<hr noshade> 

呈现 结果 实心 分 隔 线 (无 阴影 ) 

2.1.3 ”排版 标签 


1. 文字 置 左 、 置 中 、 置 右 
使 用 方法 : 刚刚 介绍 的 分 段 标签 二 p 之 再 加 上 一 些 简单 的 属性 设 定 ,就 可 以 让 其 整个 
文字 段落 置 左 、 置 中 或 置 右 了 ,如 表 2-3 所 示 。 


表 2-3 align 属性 


原始 代码 


呈现 结果 


<p align= "left"> 文 字 置 左 < /p> 文字 置 左 


<p align= "center"> 文 字 置 中 </p> 文字 置 中 
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标签 解说 : align 是 分 段 标签 二 p 二 的 属性 之 一 , 它 的 功能 是 专门 设 定 “ 水 平 对 齐 位 
置 ”, 其 常见 的 设 定 值 有 三 个 , 即 置 左 (align= "left")、 置 中 (align 王 "center") 和 置 右 (align 
一 "right") 。 
2. 向 右 缩 排 标签 
使 用 方法 : 
<blockquote> 要 缩 排 的 文字 < /blockquote> 
标签 解说 : 利用 二 blockquote 记 二 /blockquote 二 标签 可 以 将 其 包 起 来 的 文字 ,全 部 往 右 
缩 排 。 而 且 加 一 组 标签 , 往 右 缩 排 一 个 单位 ,加 两 组 标签 , 往 右 缩 排 两 个 单位 , 依 此 类 推 。 
使 用 范例 如 表 2-4 所 示 。 
表 2-4 blockquote 属性 
原始 代码 呈现 结果 
<blockquote> 缩 排 1 单位 < /blockquote> 缩 排 1 单位 


<blockquote><blockquote> 缩 排 2 单位 
</blockquote>< /blockquote> 


缩 排 2 单位 


3. 保存 原始 格式 标签 
使 用 方法 : 
<pre> 文 字 内 容 <pre> 


标签 解说 : 利用 和 pre 二 二/pre 二 标签 可 以 将 其 包 起 来 的 文字 排版 ,格式 ,原封 不 动 
地 呈现 出 来 。 


使 用 范例 如 表 2-5 所 示 。 
表 2-5 ”pre 属性 
原始 代码 呈现 结果 
<pre> 
文 字 文 字 
格 式 格 式 
< /pre> 


2.1.4 字体 标签 
1. 标题 标签 
使 用 方法 : 
<hl> 标 题 内 容 < /hl> 


标签 解说 : 标题 的 大 小 一 共有 6 种 ,两 个 标签 一 组 ,也 就 是 二 hl 之 一 二 h6 二 ,二 hl> 
最 大 ,二 h6 二 最 小 。 使 用 标题 标签 时 ,该 标签 会 将 字体 变 成 粗 体 字 ,并 且 会 自 成 一 行 。 
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使 用 范例 如 表 2-6 所 示 。 


表 2-6 标题 标签 
原始 代码 呈现 结果 
<hl> 标 题 一 < /hl> 标题 一 
<h2> 标 题 二 < /h2> 标题 二 
<h6> 标 题 六 < /h6> 标题 六 


2. 设 定 字体 大 小 标签 

使 用 方法 : 

<font size=3> 文 字 内 容 < /font> 

标签 解说 : 标题 的 大 小 一 共有 7 种 ,也 就 是 二 font size 王 1 二 (最 小 ) 一 一 font size 一 
7 二 (最 大 )。 另 外 ,还 有 一 种 写法 “二 font size 一 十 1 过 文字 内 容 一 /font 之 ”。 其 意思 就 是 
说 , 比 预 设 字 大 一 级 。 当 然 , 也 可 以 是 font size== 十 2( 比 预 设 字 大 二 级 ) ,或 是 font size 一 
一 1( 比 预 设 字 小 一 级 ) ,一 般 而 言 , 预 设 字体 多 为 3 。 

使 用 范例 如 表 2-7 所 示 。 

表 2-7 字体 大 小 标签 


原始 代码 呈现 结果 
<font size=1> 字 体 一 < /font> 或 是 字体 一 
<font size=-2> 字 体 一 < /font> 
<font size=2> 字 体 二 < /font> 或 是 字体 二 
<font size=-1> 字 体 二 < /font> 
<font size= 6> 字 体 七 </font> 或 是 
<font size=+ 4> 字 体 七 < /font> 字体 二 
3. 字 型 变化 标签 
使 用 方法 : 
<b> 文 字 < /b> 


标签 解说 : 在 文字 标签 里 ,对 于 文字 的 格式 也 有 相当 多 的 变化 ,如 粗 体 、 斜 体 等 ,此 
外 ,也 定义 了 一 些 现成 的 格式 供 编者 使 用 ,如 “强调 ”“ 原 始 代 码 " 等 。 当 然 , 这 只 是 方便 读 
者 参考 ,并 没有 强迫 说 遇 到 原始 代码 就 要 加 上 “原始 代码 ”的 标签 。 
使 用 范例 如 表 2-8 所 示 。 
表 2-8 ” 字 型 变化 标签 
原始 代码 呈现 结果 
<b> 粗 体 </b> 粗 体 
< 这 斜体 </i> 和 立体 
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续 表 
原始 代码 呈现 结果 
< 迪 底 线 </u> 底线 
<sup> 上 标 < /sup> 上 标 
<sub> 下 标 < /sub> 下 标 
4. 文字 颜色 设 定 
使 用 方法 : 


<font color="# fefecp"> 文 字 颜色 < /font> 


标签 解说 : 文字 也 可 以 设 定 颜色 。 
使 用 范例 如 表 2-9 所 示 。 


表 2-9 文字 颜色 设 定 


原始 代码 呈现 结果 
<font color= "# ff0000"> 红 < /font> 红色 的 字 
<font color= "# c0c0c0"> 灰 < /font> 灰色 的 字 


2.1.5 文字 标签 

1. 文字 字 型 设 定 

使 用 方法 : 

<font face=" 字 型 名 称 "> 文 字 < /font> 


标签 解说 : 网 页 上 也 可 以 使 用 字 型 。 唯 一 的 一 个 限制 是 对 方 也 要 有 该 字 型 ,否则 看 
到 的 仍然 还 是 宋体 。 另 外 要 说 明 的 是 ,这 个 标签 并 不 能 保证 在 每 个 浏览 器 上 都 能 正常 地 
显现 ,看 不 到 特殊 的 字 型 时 ,浏览 器 仍 会 以 宋体 来 显示 。 

使 用 范例 如 表 2-10 所 示 。 


表 2-10 文字 字 型 设 定 


原始 代码 呈现 结果 
<font face= "楷体 _GB2312"> 楷 体 _GB2312< /font> 楷体 _GB2312 
<font face=" 华 康 俩 中 黑 "> 华 康 俩 中 黑 < /font> 华 康 债 中 黑 
2. 特殊 字 元 

使 用 方法 : 

&nbsp; 


标签 解说 : 很 多 特殊 的 符号 是 需要 特别 处 理 的 ,如 二 ,二 这 两 个 符号 若 想 要 呈现 在 网 
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页 上 是 没有 办 法 直接 打 一 的 ,要 呈现 一 必须 输入 编码 表示 法 “&1t;”, 常 用 的 方法 如 下 。 
使 用 范例 如 表 2-11 所 示 。 


表 2-11 特殊 字 元 
原始 代码 呈现 结果 
gnbsp; (& nbsp; 代 表 一 个 不 断 行 空白 ) 
&lt; < 
&gt; > 
&amp; & 
&quot; 
3. 设 定 文字 内 定 值 大 小 
使 用 方法 : 


<basefont size="1~7"> 


标签 解说 : 这 个 标签 可 以 改变 文字 大 小 的 内 定 值 ,直接 加 在 二 body 二 标签 之 后 就 行 
了 。 一般 而 言 ,若是 没有 特别 设 定 , 文 字 大 小 内 定 值 预定 值 为 3。 


2.1.6 影像 标签 


1. 影 


像 标签 


在 使 用 影像 标签 时 要 注意 文档 名 和 路 径 。 

使 用 方法 : 

<img src= "boy.gif" alt=" 本 站 特约 模特 儿 " align= right border= 0 hspace= 2 vspace=2 height 

=56 width= 32> 

标签 解说 : 目前 常见 的 网 页 图 形 格式 有 两 种 ,就 是 gf 及 jpg 格式 。gif 格式 只 有 256 
色 , 不 过 色彩 比较 鲜艳 干净 漂亮 ,适合 计算 机 美工 图 案 。 而 jpg 格式 的 图 案 是 全 彩 失 真 压 
缩 ,比较 适合 一 大 堆 颜色 的 图 片 ,如 照片 就 较 适 合用 jpg 格式 来 呈现 。 

使 用 范例 如 表 2-12 所 示 。 


表 2-12 img 标签 中 的 用 法 


用 法 : 一 img src 一 "图 档 名 称 . 路径" 全 


基本 用 法 | 显示 图 片 最 基本 的 方法 (就 是 不 加 任何 属性 ) ,其 中 boy. gif 就 是 图 档 的 档 名 
原始 代码 | <img src= "images/G- FASE4.GIF"> 嗨 ! 我 是 本 站 的 模特 儿 喔 ! 
呈现 结果 审 ， 我 是 本 站 的 模特 儿 唾 ? 
左右 间距 用 法 : 一 img src 二 "图 档 " hspace 一 " 离 左 右 物 件 的 距离 "之 
离 文字 的 水 平 距离 ,通常 多 少 也 设 一 点 ,以 免 结 文字 太 近 ,看 起 来 才 不 会 有 太 挤 的 感觉 
原始 代码 | 左边 的 字 < img src= "images/G- FASE4.GIF" hspace= "15"> 右 边 的 字 
呈现 结果 左边 的 字 盘 右边 的 字 
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2. 网 页 影像 重要 观念 
关于 路 径 : 如 果 路 径 不 对 ,不 管 网 页 名 称 写 得 多 正确 也 没 用 ,因为 浏览 器 无 法 按照 路 
径 去 找到 该 有 的 图 片 。 几 种 常见 的 情形 如 表 2-13 所 示 。 


表 2-13 网 页 影像 
html 档 的 位 置 | 图 档 的 位 置 写法 情形 说 明 
c:\demo c:\demo <img src= "tad. gif"> 图 文 均 在 同一 目录 
c:\demo c:\demo\images | 一 img src 一 "images/tad. gif" 盖 “| 图 在 网 页 下 一 层 目录 
ci:\demo c:\ <img src=" .. /tad. gif"> 图 在 网 页 上 一 层 
c:\demo c:\image 二 img src 一 " image/tad. gif" 盖 “| 图 文 在 同一 层 但 不 同 目录 
“../ "是 回 到 上 一 层 目录 的 意思 。images/ 则 是 进入 下 一 层 目录 image 之 意 ,而 ima- 


ges/ 的 意思 就 是 , 回 到 上 一 层 目录 ,然后 再 进入 目录 images 中 。 以 上 使 用 的 均 为 “相对 路 
径 ” 的 概念 。 

影像 单位 : 或 许 常常 会 看 到 px 这 个 单位 ,这 个 单位 完整 的 写法 是 pixels, 称 为 “ 像 
素 ”。 

影像 格式 : 网 页 用 的 图 档 目 前 只 有 gif 格式 ( 即 副 档 名 为 gif 的 图 档 , 如 bg. gif) 及 jpg 
格式 ( 即 副 档 名 为 jpg 的 图 档 ,如 bg. jpg) 为 一 般 的 浏览 器 所 接受 。 其 他 如 bmp 格式 或 是 
pcx 格式 都 是 无 法 在 网 页 上 使 用 的 。 


2.1.7 背景 标签 


1. 背景 标签 

背景 标签 只 有 过 BODY 二 这 个 标签 ,其 余 的 效果 ,只 要 加 上 一 些 简单 的 属性 便 可 
做 到 。 

使 用 方法 : 

<body bgcolor= "# ffffff" background= "bg.jpg"> 

标签 解说 : 这 个 标签 是 构成 网 页 不 可 或 缺 的 基本 要 素 之 一 。 背 景 颜色 或 图 片 的 设 定 
及 链接 字体 的 颜色 ,都 放 在 二 body 二 标签 里 面 。 

2. 内 文 链接 文字 颜色 设 定 

使 用 方法 : 

<body text= "#000000" link= "#0000ff" vlink= "#f£f00ff" alink="# ff£0000> 

标签 解说 用 字体 标签 中 的 颜色 属性 ,可 以 设 定 文字 的 颜色 ,在 二 body 二 标签 中 , 便 
有 设 定 内 文 、 链 接 等 文字 的 颜色 内 定 值 功能 。 用 法 如 表 2-14 所 示 。 
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表 2-14 设 定 内 文 颜色 


内 文 颜色 用 法 : 二 body text==" 颜 色 码 "二 


<html> 

<head> 

<title> 这 是 标题 < /title> 
< /head> 

<body text="# 0906a2"> 

这 里 是 本 文 区 

< /body> 

</htm> 


原始 代码 


避 这 是 标题 - 了 icros--- 
文件 GE) 编辑 人 ) 查看 Q) 


加 -回国 


呈现 结果 
这 里 是 本 文 区 


使 用 范例 如 表 2-15 所 示 。 


表 2-15 设 定 链接 文字 


用 法 : 二 body link= 二 "颜色 码 " 二 
链接 颜色 设 定 "链接 "的 颜色 。 只 要 是 有 链接 的 地 方 就 会 出 现 指定 的 颜色 ,当然 ,如 果 按 
下 链接 后 , 那 又 会 变 成 另 一 个 颜色 了 ,下 面 会 说 明 


<html> 

<head><title> 这 是 标题 < /title> 
</head> 

原始 代码 <body link= "# ff6600"> 

<a href= "index.htm"> 链 接 文字 < /a> 
</body> 

</htm> 


当 这 是 标题 

文件 四 蝙 辑 到 ) 查看 Q ” 
@@ 包 -四 : 回 国 “ 
地 址 四 ) | 蛋 x-et 同 | 加 轩 到 “” 链 皖 
呈现 结果 
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2.1.8 链接 标签 


1. 链接 标签 基本 概念 
链接 基本 概念 : 一 般 而 言 ,链接 就 是 在 网 页 中 有 些 字 会 有 特别 的 颜色 ,而 且 字 的 底下 
会 有 条 线 , 当 游标 移 到 那些 字 上 时 ,会 变 成 手指 形状 。 整 理 如 表 2-16 所 示 。 
表 2-16 ”相对 路 径 和 链接 位 置 


相对 路 径 表示 方式 代表 链接 位 置 
RS 人 htm 在 目前 的 目录 中 (就 例子 而 言 ,就 是 在 c:\www 


=a href="docs/textl. htm"> textl htm 在 名 为 docs 的 次 目录 中 (就 本 例 而 言 ,就 是 在 c:\ 
www\docs 中 ) 
ard /endlidt> Us 在 目前 目录 的 上 一 层 目录 中 (就 本 例 而 言 ,就 是 在 


2. 网 页 内 部 的 链接 

使 用 方法 : 先 在 欲 链接 处 作 记号 二 a name 二 "herel" 二 这 里 是 想 链接 的 点 二 /a 这。 
设 定 链接 : 二 a href="# herel "之 链接 二 /a> 

标签 解说 : 当 某 页 的 内 容 很 多 时 ,可 以 利用 网 页 的 内 部 链接 ,让 使 用 者 快速 找到 资料 。 
使 用 范例 如 表 2-17 所 示 。 


表 2-17 网 页 的 链接 步骤 


范例 第 1 步 第 2 步 
www 链接 标签 基本 | a name 一 "ml" 之 僻 链接 的 位 | a href 一 "# m1" 这 www 链接 标签 基本 
概念 置 </a> 概念 1a> 
过 a name 二 "ma" 之 佑 链接 的 位 | a href 二 " # m2" 之 网 页 内 部 的 链 按 
风 闪 内部 内 相 六 置 </a> </a> 

过 a nome 二 " m3" 之 佑 链接 的 位 | a href 二" # ms 六 网页 外 部 的 链接 
网 页 外 部 的 链接 。 | 下 Ca = 


3. 网 页 外 部 的 链接 


标签 解说 : 链接 到 外 面 去 ,可 以 扩充 网 站 的 实用 性 及 充实 性 。 由 于 网 络 上 的 服务 内 
容 丰 富 , 所 以 不 同 的 服务 有 不 同 的 链接 方法 ,将 之 整理 如 下 。 
使 用 范例 如 表 2-18 所 示 。 


表 2-18 外 部 网 的 链接 


网 站 链接 好 站 a href="http://sunspot-design. com" 二 好 站 一 /a> 


电子 邮件 链接 写 信 给 我 二 a href 一 "mailto:cctv@hotmail. com" 之 写 信 给 我 一 /a> 


ftp 链接 下 载 档案 二 a href 一 "ftp://ftp. ntu. edu. tw" 二 下 载 档案 一 /a> 
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续 表 
< =" ” Ee E 本 
news 链接 cae eal a href 一 "news:news. seed. net. tw"> seednet news 服务 
</a> 
一 a href 一 "gopher://gopher. seed. net. tw/"> seednet go- 
gopher 链接 seednet gopher 服务 i 
a href="telnet./ /bbe. seed. net. tw/™ 
bbs 链接 seednet bbs 服务 a href= "telnet://bbs. seed. net. tw/ "二 seednet bbs 服务 
</a> 
4. 链接 标签 的 参数 


使 用 方法 : 在 链接 后 面 加 入 target 一 _ 参 数 。 

标签 解说 : 链接 的 参数 并 不 多 ,常见 的 大 概 就 属 target 这 个 参数 了 。target 的 意思 
是 “目标 ”, 也 就 是 网 页 链接 的 指向 目标 ,该 参数 在 框 窗 (frame) 里 尤为 重要 。 

使 用 范例 如 下 。 

。 target 二 框 窗 名 称 : 这 在 “框架 标签 "中 也 有 提 到 ,而 且 也 只 有 在 框架 ( 框 窗 or 
frame) 中 才 用 得 到 。 正 常 而 言 , 框 窗 有 各 自 的 名 称 , 因 此 ,可 以 利用 此 标签 ,来 指 
定 链接 的 内 容 显 示 到 哪 一 个 框 窗 中 。 
target 一 _blank: 将 链接 的 画面 内 容 , 开 在 新 的 浏览 视窗 中 。 
target 王 _parent: 将 链接 的 画面 内 容 , 当 成 文件 的 上 一 个 画面 。 
target 二 _self: 将 链接 的 画面 内 容 , 显 示 在 目前 的 视窗 中 。 
target 一 _top: 这 个 参数 可 以 解决 新 链接 的 画面 内 容 被 旧 框 窗 包 围 的 困扰 ,使 用 这 
个 参数 ,会 将 整个 画面 重新 显示 成 链接 的 画面 内 容 。 


2.1.9 表格 标签 


1. 网 页 中 的 表格 观念 
范例 如 表 2-19 所 示 。 
表 2-19 在 表格 中 设置 一 个 格子 


原始 代码 呈现 结果 
<TRABLE BORDER= 1> 站 
<TR> <TD> 1< /TD> < /TR> < /TABLE> 


利用 天 TABLE> 标 签 来 告诉 计算 机 ,这 是 一 个 表格 ,至 于 BORDER 二 1 这 个 参数 是 
设 定 此 表格 的 框 线 粗细 为 1。 一 组 二 TR 二 二 /TR 是 设 定 一 横 列 的 开始 ,一 组 二 TD 二 
去 /TD> 则 是 设 定 一 个 栏 位 。 现 在 再 来 增加 两 个 格子 ,如 表 2-20 所 示 。 
表 2-20 在 表格 中 增加 两 个 格子 
原始 代码 呈现 结果 


< TABLE BORDER= 1> 
<TR> <TD>1< /TD><TD>2< /TD><TD>3< /TD>< /TR> 
< /TABLE> 


eal 
器 
[mal 
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2. 表格 栏 位 对 齐 位 置 设 定 
现在 制作 一 个 宽 100、 高 60 的 表格 ,做 法 如 表 2-21 所 示 。 
表 2-21 左 对 齐 


原始 代码 呈现 结果 


< TABLE WIDTH= "100" BORDER= "1" HEIGHT= "60"> | 


<TR> <TD> 1< /TD>< /TR>< /TABLE> 


在 二 TD> 加 入 ALIGN 二 CENTER 参数 , 即 可 得 到 1 居中 的 结果 ,如 表 2-22 所 示 。 


表 2-22 居中 
原始 代码 呈现 结果 
< TABLE WIDTH= "100" BORDER= "1" HEIGHT= "60"> 
1 
<TR><TD ALIGN= CENTER> 1< /TD> < /TR> < /TABLE> CC | 


此 外 ,利用 ALIGN=RIGHT 可 以 让 表格 中 物件 置 右 、 利 用 ALIGN==LEFT 可 以 让 
表格 中 物件 置 左 ( 预 设 值 ) 。 

利用 VALIGN 二 MIDDLE 可 以 让 表格 中 物件 垂直 置 中 ( 预 设 值 ), VALIGN = BOT- 
TOM 可 以 让 表格 中 物件 靠 下 方 对 齐 。 利 用 VALIGN=TOP 这 种 属性 即 可 让 表格 内 物 
件 靠 上 方 对 齐 。 

3. 表格 背景 、 底 色 设 定 

利用 BGCOLOR= "颜色 码 " 就 可 以 改变 表格 的 底 色 。 表 2-23 介绍 指定 整 格 表格 背 
景 颜色 的 方法 。 

表 2-23 设置 表格 背景 颜色 


原始 代码 呈现 结果 


< TABLE BORDER= "1" BGCOLOR= # FFCC33> 


<TR> <TD> 1< /TD> < TD> 2< /TD> < /TR> 加 
<TR><TD>3</TD><TD>4</TD></TR> 9 
< /TABLE> 


将 BGCOLOR=" 颜 色 码 "加 在 二 TR 二 中 ,可 以 指定 一 行 的 背景 颜色 ,如 表 2-24 
所 示 。 


表 2-24 设置 一 行 的 背景 颜色 


原始 代码 呈现 结果 
<TRABLE BORDER= "1" > 

<TR BGCOLOR=# FFCC33>< TD> 1< /TD> [ 虽 
<TD> 2< /TD> < /TR> < TR><TD> 3< /TD> < TD> 4< /TD> Bh 

< /TR> < /TABLE> 


将 BGCOLOR =" 颜 色 码 "加 在 二 TD 二 中 ,可 以 指定 一 格 的 背景 颜色 ,如 表 2-25 
所 示 。 
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表 2-25 设置 一 格 的 背景 颜色 
原始 代码 呈现 结果 


< TABLE BORDER= "1" ><TR> 本 
<TD BGCOLOR=#FFCC33> 1< /TD> < TD> 2< /TD> < /TR> 
<TR> <TD> 3< /TD> < TD> 4< /TD>< /TR> < /TABLE> 


表格 除了 可 以 设 定 底 色 外 ,也 可 以 用 图 片 来 作 背 景 。 只 要 将 BACKGROUND=" 图 
片 名 称 " 加 到 表格 中 就 行 了 。 和 表格 背景 颜色 一 样 , 不 但 表格 可 以 设 定 背景 图 片 ,也 可 以 
指定 某 栏 或 某 列 的 背景 图 片 。 

将 BACKGROUND=" 图 片 名 称 " 加 在 二 TD 二 中 ,可 以 指定 一 栏 的 背景 颜色 ,具体 方 
法 见 下 例 。 

4. 表格 框 线 设 定 

利用 BORDER==" 粗 细 值 "可 以 设 定 表格 粗细 ,如 表 2-26 所 示 。 


表 2-26 设置 表格 边框 粗细 
原始 代码 呈现 结果 


< TABLE BORDER= 5>< TR><TD> 1< /TD>< /TR> < /TABIE> 品 


利用 BORDERCOLOR= "颜色 码 " 可 以 设 定 表格 颜色 ,如 表 6-27 所 示 。 
表 6-27 设置 表格 颜色 


原始 代码 呈现 结果 
< TABLE BORDER= "5”BORDERCOLOR= "# 0080FF"> 日 
<TR> <TD> 1< /TD></TR>< /TABLE> 


另外 ,利用 BORDERCOLORLIGHT=="# 颜 色 码 "( 亮 面 设 定 ) BORDERCOLOR- 
DARK= "颜色 码 "( 暗 面 设 定 ) 可 以 设 定 表格 的 阴影 、 亮 面 颜色 ,如 表 2-28 所 示 。 
表 2-28 设置 表格 的 阴影 、 亮 面 颜色 
原始 代码 呈现 结果 


< TABLE BORDER= "5" BORDERCOLOR= "# 0080FF™ 
BORDERCOLORLIGHT= "# 62BOFE™ 
BORDERCOLORDARK= "# 004B97"> 日 
<TR><TD>1< /TD>< /TR> 
< /TABLE> 


5. 表格 栏 距 设 定 
利用 CELLPADDING 属性 自由 设 定 表 格 内 文 距离 格 线 的 距离 ,如 表 2-29 所 示 。 
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表 2-29 设置 表格 内 文 距离 格 线 的 距离 


原始 代码 呈现 结果 
<TRBIE BORDER= "1" CELLPADDING= "10"> | 
<TR> <TD> 1< /TD>< TD> 2< /TD>< /TR> < /TABLE> 


利用 CELLSPACING 属性 设 定 表格 栏 位 格 线 之 间 的 距离 ,如 表 2-30 所 示 。 
表 2-30 设置 表格 栏 位 格 线 之 间 的 距离 


原始 代码 呈现 结果 
< TABLE BORDER= "1" CELLSPACING= "5"> 丽 
<TR> <TD> 1< /TD>< TD> 2< /TD>< /TR> < /TABLE> 


2.1.10 序列 标签 


1. 无 序 标签 

序列 标签 基本 上 可 分 为 两 种 ,一 种 是 “无 序 条 列 ”, 一 种 是 “有 序 条 列 ”。“ 无 序 条 列 ” 就 
是 指 各 条 列 间 并 无 顺序 关系 ,纯粹 只 是 利用 条 列 式 方法 来 呈现 资料 而 已 ,此 种 无 序 标签 ， 
在 各 条 列 前 面 均 有 一 符号 以 示 区 隔 。 至 于 “有 序 条 列 " 就 是 指 各 条 列 之 间 是 有 顺序 的 ,从 
1、2、3、… 一 直 延 伸 下 去 。 

首先 介绍 “无 序列 表 标 签 ” 的 使 用 ,如 表 2-31 所 示 。 


表 2-31 无 序 标签 的 使 用 方法 


原始 代码 呈现 结果 


<UL><LI> 姓 名 : 杰出 

<LI> 生 日 : 1974/11/21 〇 姓名: 杰出 

<LI> 星 座 : 天 蝎 座 〇 ”生日 : 1974/11/21 
O 〇 星座 : 天 蝎 座 

</UL> 


其 中 二 UL 标签 即 为 “无 序列 表 标签 ”, 每 增加 一 列 内 容 , 就 必须 加 一 个 二 LI>。 
前 面 的 符号 可 以 通过 TYPE==" 形 状 名 称 "属性 来 改变 其 符号 形状 .一 共有 三 个 选择 : 
DISK( 实 心 圆 )\ SQUARE( 小 正方 形 ) 和 CIRCLE( 空 心 圆 ) 。 


2. 有 序 标签 
首先 介绍 “有 序列 表 标 签 ”的 使 用 ,如 表 2-32 所 示 。 
表 2-32 ”有 序 标签 的 使 用 方法 


原始 代码 呈现 结果 
<OL><LI> 姓 名 : 杰出 

1。 姓名 : 杰出 
2 2. 生日 : 1974/11/21 
ee 3.， ”星座 : 天 蝎 座 
</OL> 


其 中 过 OL> 标 签 即 为 “有 序列 表 标 签 ”, 每 增加 一 列 内 容 , 就 必须 加 一 个 二 LI 之 。 和 
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无 序列 表 标签 一 样 ,也 可 以 选择 不 同 的 符号 来 显示 顺序 ,一 样 是 用 TYPE 属性 来 作 更 改 。 
一 共有 5 种 符号 : 1( 数 字 )、A (大 写 英 文字 母 )、a( 小 写 英文 字母 )、I( 大 写 罗马 字母 ) 和 i 
(小 写 罗马 字母 )。 

可 指定 序列 起 始 的 数目 ,其 方法 如 表 2-33 所 示 。 


表 2-33 ”指定 起 始 序 列 的 方法 


原始 代码 呈现 结果 

<OL START= "8"> 

<LI> 姓 名 : 杰出 8. 姓名 : 杰出 
<LI> 生 日 : 1974/11/21 9. 生日 : 1974/11/21 
<LI> 星 座 : 天 蝎 座 10. ”星座 : 天 蝎 座 
</oL> 


2.1.11 表单 标签 


1. 各 种 输入 类 型 

文字 输入 列 : 每 个 表单 之 所 以 会 有 不 同 的 类 型 ,原因 就 在 于 TYPE=" 表 单 类 型 " 设 
定 的 不 同 而 已 。 首 先 来 看 看 第 一 个 类 型 : 文字 输入 列 。 文 字 输 入 列 的 形态 就 是 TYPE 
一 "TEXT" ,其 使 用 方法 如 表 2-34 所 示 。 

表 2-34 文字 输入 列 的 使 用 方法 
窗 体 项 端 


呈现 结果 姓名 : 
窗 体 底 端 


<FORM> 
原始 代码 姓名 : <INPUT TYPE= "TEXT" NAME= "NAME" SIZE= "20"> 
< /FORM> 


其 有 下 列 可 设 定 的 属性 。 
NAME 王 "名 称 ": 设 定 此 栏 位 的 名 称 ,程式 中 常会 用 到 。 
SIZE= "数值 ": 设 定 此 栏 位 显现 的 宽度 。 
VALUE= " 预 设 内 容 ": 设 定 此 栏 位 的 预 设 内 容 。 
ALIGN 王 "对 齐 方式 ": 设 定 此 栏 位 的 对 齐 方式 ,其 值 有 TOP( 向 上 对 齐 )、MID- 
DLE( 向 中 对 齐 ) .BOTTOM( 向 下 对 齐 )、RIGHT( 向 右 对 齐 )、LEFT( 向 左 对 齐 )、 
TEXTTOP( 向 文字 顶部 对 齐 )、BASELINE( 向 文字 底部 对 齐 )、ABSMIDDLE( 绝 
对 置 中 ) 和 ABSBOTTOM( 绝 对 置 下 ) 等 。 

。 MAXLENGTH= "数值 ": 设 定 此 栏 位 可 设 定 输入 的 最 大 长 度 。 

单 选 核 取 表单 : 利用 TYPE 王 "RADIO" 就 会 产生 单 选 核 取 表单 。 单 选 核 取 表单 通常 
是 好 几 个 选项 一 起 摆 出 来 供 使 用 者 点 选 ,一 次 只 能 从 中 选 一 个 , 故 为 单 选 核 取 表单 ,如 
表 2-35 所 示 。 
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表 2-35 单 选 核 取 表 单 的 使 用 方法 


窗 体 顶 端 
呈现 结果 性 别 : 男人 女 全 
窗 体 底 端 


<FORM> 性 别 : 

原始 代码 男 <INPUT TYPE= "RADIO" NAME="SEX" VALUE= "BOY"> 女 
< INPUT TYPE- "RADIO" NAME~= "SEX" VALUE= "GIRL"> 

< /FORM> 


其 有 下 列 可 设 定 的 属性 。 

。 NAME== "名称"; 设 定 此 栏 位 的 名 称 , 程 式 中 常会 用 到 。 

。 VALUE==" 内 容 ": 设 定 此 栏 位 的 内 容 、 值 或 是 意义 。 

。 ALIGN 王 "对 齐 方式 ": 设 定 此 栏 位 的 对 齐 方式 ,其 值 有 TOP( 向 上 对 齐 ) .MID- 
DLE( 向 中 对 齐 )、BOTTOM( 向 下 对 齐 )、RIGHT( 向 右 对 齐 )、LEFT( 向 左 对 齐 )、 
TEXTTOP( 向 文字 顶部 对 齐 )、BASELINE( 向 文字 底部 对 齐 )、.ABSMIDDLE( 绝 
对 置 中 ) 和 ABSBOTTOM( 绝 对 置 下 ) 等 。 

。 CHECKED: 设 定 此 栏 位 为 预 设 选取 值 。 

复 选 核 取 表单 : 利用 TYPE==" CHECKBOX "就 会 产生 复 选 核 取 表单 。 复 选 核 取 表 


单 通常 是 好 几 个 选项 一 起 摆 出 来 供 使 用 者 点 选 , 一 次 可 以 同时 选 好 几 个 , 故 为 复 选 核 取 表 
单 如 表 2-36 所 示 。 


表 2-36 复 选 核 取 表 单 的 使 用 方法 
窗 体 项 端 


呈现 结果 喜好 : 口 电影 口 看 书 


窗 体 底 端 


原始 代码 


<FORM> 喜 好 : 

< INPUT TYPE= "CHECKBOX”NRME= "SEX" 
VALUE= "MOVIE"> 电 影 

< INPUT TYPE= "CHECKBOX"”NRME= "SEX" 
VALUE= "BOOK"> 看 书 

< /FORM> 


其 有 下 列 可 设 定 的 属性 。 

NAME= "名称 ": 设 定 此 栏 位 的 名 称 ,程式 中 常会 用 到 。 

VALUE= "内 容 ": 设 定 此 栏 位 的 内 容 、 值 或 是 意义 。 

ALIGN 王 "对 齐 方式 ": 设 定 此 栏 位 的 对 齐 方式 ,其 值 有 TOP( 向 上 对 齐 ) .MID- 
DLE( 向 中 对 齐 )、BOTTOM( 向 下 对 齐 )、RIGHT( 向 右 对 齐 )、LEFT( 向 左 对 齐 )、 
TEXTTOP( 向 文字 顶部 对 齐 )、BASELINE( 向 文字 底部 对 齐 )、ABSMIDDLE( 绝 
对 置 中 ) 和 ABSBOTTOM( 绝 对 置 下 ) 等 。 

CHECKED: 设 定 此 栏 位 为 预 设 选取 值 。 
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密码 表单 : 利用 TYPE 二 " PASSWORD "就 会 产生 一 个 密码 表单 。 密 码 表单 和 文字 


输入 表单 长 得 几乎 一 样 ,差别 就 在 于 密码 表单 在 输入 时 全 部 会 以 星 号 来 取代 输入 的 文字 ， 
以 防 他 人 偷窥 ,如 表 2-37 所 示 。 


表 2-37 ”密码 表单 的 使 用 方法 


窗 体 项 端 


呈现 结果 请 输入 密码 : 
窗 体 底 端 


< FORM> 

请 输入 密码 : 

< INPUT TYPE= "PASSWORD" NAME= "INPUT"> 
< /FORM> 


原始 代码 


其 有 下 列 可 设 定 的 属性 。 

。 NAME== "名称"; 设 定 此 栏 位 的 名 称 , 程 式 中 常会 用 到 。 

SIZE= "数值 ": 设 定 此 栏 位 显现 的 宽度 。 

VALUE==" 预 设 内 容 ": 设 定 此 栏 位 的 预 设 内 容 , 不 过 呈现 出 来 仍 是 星 号 。 
ALIGN 王 "对 齐 方式 ": 设 定 此 栏 位 的 对 齐 方式 ,其 值 有 TOP( 向 上 对 齐 )、MID- 
DLE( 向 中 对 齐 ) .BOTTOM( 向 下 对 齐 )、RIGHT( 向 右 对 齐 )、LEFT( 向 左 对 齐 )、 
TEXTTOP( 向 文字 顶部 对 齐 )、BASELINE( 向 文字 底部 对 齐 ) 和 ABSMIDDLE 
(绝对 置 中 ) 等 。 

。 MAXLENGTH= "数值 ": 设 定 此 栏 位 可 设 定 输入 的 最 大 长 度 。 

送出 按钮 : 通常 在 表单 填 完 之 后 ,都 会 有 一 个 送出 按钮 及 清除 重 写 的 按钮 ,分 别 是 利 


用 TYPE="SUBMIT" 及 TYPE="RESET" ,如 表 2-38 所 示 。 


表 2-38 ”送出 按钮 的 使 用 方法 
窗 体 项 端 
呈现 结果 送出 资料 | 重新 填写 


窗 体 底 端 


<FORM> 

< INPUT TYPE= "SUBMIT" VALUE= "送出 资料 "> 
原始 代码 < INPUT TYPE= "RESET" VALUE= "重新 填写 "> 
< /FORM> 


其 有 下 列 可 设 定 的 属性 。 

。 NAME=" 名 称 ": 设 定 此 按钮 的 名 称 。 

。 VALUE= "文字 ": 设 定 此 按钮 上 要 呈现 的 文字 .若是 没有 设 定 .浏览 器 也 会 自动 
替 用 户 加 上 “送出 查询 ”“ 重 设 ” 等 字样 。 

ALIGN 一 "对 齐 方式 ": 设 定 此 栏 位 的 对 齐 方式 ,其 值 有 TOP( 向 上 对 齐 )、MID- 
DLE( 向 中 对 齐 )、BOTTOM( 向 下 对 齐 )、RIGHT( 向 右 对 齐 )、LEFT( 向 左 对 齐 )、 
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TEXTTOP( 向 文字 顶部 对 齐 )、BASELINE( 向 文字 底部 对 齐 )、ABSMIDDLE( 绝 
对 置 中 ) 和 ABSBOTTOM( 绝 对 置 下 ) 等 。 
按钮 元 件 : 表单 中 或 是 JavaScript 常会 用 到 按钮 来 作 一 些 效果 ,因此 ,可 以 利用 
TYPE 二 "BUTTON" 来 产生 一 个 按钮 ,如 表 2-39 所 示 。 
表 2-39 ”按钮 元 件 的 使 用 方法 
窗 体 项 端 


呈现 结果 请 按 下 按钮 医 E| 
窗 体 底 端 


<FORM> 请 按 下 按钮 : 
原始 代码 <INPUT TYPE= "BUTTON" NAME= "OK" VALUE= "我 同意 "> 
< /FORM> 


其 有 下 列 可 设 定 的 属性 。 

。NAME=" 名 称 ": 设 定 此 按钮 的 名 称 。 

。 VALUE== "文字": 设 定 此 按钮 上 要 呈现 的 文字 。 

。 ALIGN= "对齐 方 式 ": 设 定 此 栏 位 的 对 齐 方式 ,其 值 有 TOP( 向 上 对 齐 ) .MID- 
DLE( 向 中 对 齐 )、BOTTOM( 向 下 对 齐 )、RIGHT( 向 右 对 齐 )、LEFT( 向 左 对 齐 )、 
TEXTTOP( 向 文字 顶部 对 齐 ) .BASELINE( 向 文字 底部 对 齐 )、ABSMIDDLE( 绝 
对 置 中 ) 和 ABSBOTTOM( 绝 对 置 下 ) 等 。 

隐藏 栏 位 : 表单 中 有 时 有 些 东西 因为 某 些 因素 ,不 想 让 使 用 者 看 到 ,但 因 程 式 需 要 却 

又 不 得 不 存在 ,可 以 利用 TYPE=”" HIDDEN "来 产生 一 个 隐藏 的 栏 位 ,如 表 2-40 所 示 。 


表 2-40 ”隐藏 栏 位 的 使 用 方法 


窗 体 项 端 
呈现 结果 隐藏 栏 位 ; [本 
窗 体 底 端 
<FORM> 隐藏 栏 位 : 
原始 代码 <INPUT TYPE= "HIDDEN" NAME= "NOSEE" VALUE= "看 不 到 "> 
< /FORM> 
其 有 下 列 可 设 定 的 属性 。 


。 NAME= "名称 ": 设 定 此 栏 位 的 名 称 。 

。 VALUE= "文字 ": 设 定 此 栏 位 的 值 .文字 或 意义 。 

2. 大 量 文字 输入 元 件 

如 果 需 要 使 用 者 输入 比较 大 量 的 文字 ,可 以 利用 二 TEXTAREA 二 一/TEXTAREA 二 来 


产生 一 个 可 以 输入 大 量 文字 的 元 件 , 夹 在 两 个 标签 中 的 文字 会 出 现在 列表 框 中 ,可 作为 预 
设 文字 ,如 表 2-41 所 示 。 
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表 2-41 大 量 文字 输入 元 件 的 使 用 方法 


窗 体 项 端 
请 输入 您 的 意见 ， 
呈现 结果 昌 
窗 体 底 端 
<FORM> 请 输入 您 的 意见 : <BR> 
原始 代码 < TEXTAREA NAME= "TALK" COLS="20" ROWS="3"> < /TEXTRRER> 
< /FORM> 
其 有 下 列 可 设 定 的 属性 。 


。 NAME== "名称" : 设 定 此 栏 位 的 名 称 。 

。 WRAP 王 " 设 定 值 ": 设 定 此 栏 位 的 换行 模式 。 设 定 值 有 三 种 : OFF( 输 入 文字 不 
会 自动 换行 )\ VIRTUAL( 输 入 文字 在 屏幕 上 会 自动 换行 ,不 过 若是 使 用 者 没有 
自行 按 Enter 键 换行 ,送出 资料 时 ,也 视 为 没有 换行 ) 和 PHYSICAL( 输 入 文字 会 
自动 换行 ,送出 资料 时 ,会 将 屏幕 上 的 自动 换行 , 视 为 换行 效果 送出 ) 。 

。 COLS= "数值 ": 设 定 此 栏 位 的 行 数 (横向 字数 ) 。 


ROWS 一 "数值 ": 设 定 此 栏 位 的 列 数 (垂直 字数 )。 
3. 下 拉 式 列表 


利用 二 SELECT NAME= "名称 "之 可 以 生成 一 个 下 拉 式 列表 ,另外 ,还 需要 配合 
所 OPTION 二 标签 来 产生 选项 ,如 表 2-42 所 示 。 


呈现 结果 


表 2-42 下 拉 式 列表 的 使 用 方法 
窗 体 项 端 


您 喜欢 看 书 吗 ?: [#5 可 


窗 体 底 端 


原始 代码 


<FORM> 

您 喜欢 看 书 吗 ? : 

< SELECT NAME= "LIKE"> 

<OPTION VALUE=- "非常 喜欢 "> 非常 喜欢 
<OPTION VALUE- "还 算 喜 欢 "> 还 算 喜 欢 
<OPTION VALUE= "不 太 喜 欢 "> 不 太 喜 欢 
<OPTION VALUE= "非常 讨厌 "> 非常 讨厌 
</SELECT> 

< /FORM> 


其 有 下 列 可 设 定 的 属性 。 
"SIZE= "数值 ": 设 定 此 栏 位 的 大 小 , 预 设 值 为 1。 
。 MULTIPLE: 设 定 此 栏 位 为 复 选 ,可 以 一 次 选 好 几 个 选项 。 
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2.1.12 框架 标签 


1. 框架 的 基本 概念 

以 图 2-1 为 例 , 一 共 分 为 1.2、3 三 个 框架 ,每 一 个 框架 ,各 有 其 显示 的 内 容 , 分 别 是 
a. htm b. htm 和 c. htm 三 个 档案 。 所 有 Frame 的 标签 .其 实 都 只 摆 在 index. htm 这 个 档 
案 里 。 


index.htm 


图 2-1 框架 示意 图 


2. 使 用 框架 标签 
创建 一 个 网 页 ,如 表 2-43 所 示 。 
表 2-43 创建 一 个 网 页 


原始 代码 呈现 结果 


<HTML><HERD> 
<TITLE> 框 窗 实 作 < /TITLE> 
< /HEAD> < /HTML> 


图 


将 画面 分 成 左右 两 边 ( 左 边 就 是 框 窗 1 了 ,右边 就 暂 定 为 2) ,如 表 2-44 所 示 。 


表 2-44 创建 2 个 网 页 


原始 代码 呈现 结果 
<HIML><HERD> 

<TITLE> 框 窗 实 作 < /TITLE> < /HEAD> 
< FRAMESET COLS= "120, * ”> 大 一 下 

1 

< FRAME SRC= "a.htm" NAME= "1"> LU 
< FRAME SRC= "b.htm” NAME= "2"> 
< /FRAMESET> < /HTML> 


在 二 FRAMESET 放 中 ,一 开始 是 左右 分 ,所 以 写成 FRAMESET COLS="120， 
x "之 。COLS="120,* "就 是 说 ,左边 那 一 栏 强制 定 为 120 点 ,右边 则 随 视窗 大 小 而 
变 。 除 了 直接 写 点 数 外 , 亦 可 用 百分比 来 表示 ,例如 COLS 二 "20%,80%" 也 是 可 以 的 。 
再 将 右边 的 框 窗 割 成 上 下 两 个 画面 (也 就 是 框 窗 2 和 3) ,如 表 2-45 所 示 。 
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表 2-45 ”进行 框 窗 的 分 割 


原始 代码 呈现 结果 


<HTML><HERD> 
<TITLE> 框 窗 实 作 < /TITLE> 
< /HEAD> 
< FRAMESET COLS= "120, * "> 

< FRAME SRC= "a.htm" NAME="1"> 

< FRAMESET ROWS= "100, * "> 
< FRAME SRC="b.htm" NAME= "2"> 

< FRAME SRC="c.htm" NAME="3"> 

< /FRAMESET> 
< /FRAMESET> < /HTML> 


原本 的 二 FRAME SRC="b. htm" NAME="2">( 在 第 3 点 的 语法 中 ) 被 另 一 组 
二 FRAMESET ROWS="100,* "二 所 取代 了 ,第 二 组 二 FRAMESET ROWS="100， 
x "过 是 被 第 一 组 FRAMESET COLS="120, * ”二 所 包围 起 来 的 。 


2.2 CSS 层 鲁 样式 表 


2.2.1 认识 CSS 


CSS 是 一 种 制作 网 页 的 新 技术 。 网 页 设计 最 初 是 用 HTML 标记 来 定义 页 面 文档 及 
格式 ,例如 标题 二 hl 二 .段落 二 p 二 .表格 二 table 之 和 链接 二 a> 等 ,但 这 些 标记 不 能 满足 
更 多 的 文档 样式 需求 。 为 了 解决 这 个 问题 ,在 1997 年 W3C(The World Wide Web Con- 
sortium) 颁 布 HTML4 标准 的 同时 也 公布 了 有 关 样 式 表 的 第 一 个 标准 CSS1。 自 CSS1 
的 版 本 之 后 ,又 在 1998 年 5 月 发 布 了 CSS2 版 本 ,样式 表 得 到 了 更 多 的 充实 。W3C 把 
DHTML(Dynamic HTML) 分 为 三 个 部 分 来 实现 : 脚本 语言 (包括 JavaScript、VBScript 
等 ) 支持 动态 效果 的 浏览 器 (包括 Internet Explorer、Netscape Navigator 等 ) 和 CSS 样 


2.2.2 CSS 语法 


1. 基本 语法 
CSS 的 定义 是 由 三 个 部 分 构成 : 选择 符 (selector) 、 属 性 (properties) 和 属性 的 取 值 


(value), 


基本 格式 如 下 : 
selector {property: value} 


选择 符 {属性 : 值 }。 选 择 符 可 以 是 多 种 形式 ,一般 是 要 定义 样式 的 HTML 标记 , 例 
如 BODY、P 和 TABLE 等 ,可 以 通过 此 方法 定义 它 的 属性 和 值 . 属 性 和 值 要 用 冒号 隔 开 。 
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选择 符 body 是 指 页 面 主体 部 分 ,color 是 控制 文字 颜色 的 属性 ,black 是 颜色 的 值 , 此 
例 的 效果 是 使 页 面 中 的 文字 为 黑色 。 

如 果 属 性 的 值 是 多 个 单词 组 成 ,必须 在 值 上 加 引号 ,例如 字体 的 名 称 经 常 是 几 个 单词 
的 组 合 了 


(定义 段落 字体 为 sans serif) 
如 果 需 要 对 一 个 选择 符 指定 多 个 属性 时 ,使 用 分 号 将 所 有 的 属性 和 值 分 开 。 


《段落 居中 排列 ,并 且 段 落 中 的 文字 为 红色 ) 
为 了 使 自 定义 的 样式 表 方便 阅读 ,可 以 采用 分 行 的 书写 格式 。 


(段落 排列 居中 ,段落 中 文字 为 黑色 ,字体 是 arial) 

2. 选择 符 组 

可 以 把 相同 属性 和 值 的 选择 符 组 合 起 来 书写 ,用 逗号 将 选择 符 分 开 ,这 样 可 以 减少 样 
式 重复 定义 : hl, h2, h3, h4, h5,h6 { color: green } (这 个 组 里 包括 所 有 的 标题 元 素 ， 
每 个 标题 元 素 的 文字 都 为 绿色 ) 。 


(段落 和 表格 里 的 文字 尺寸 为 9 号 字 ) 
效果 完全 等 效 于 : 


3. 类 选择 符 

用 类 选择 符 能 够 把 相同 的 元 素 分 类 定义 不 同 的 样式 ,定义 类 选择 符 时 ,在 自 定 类 的 名 
称 前 面 加 一 个 点 号 。 假 如 想 要 两 个 不 同 的 段落 ,一 个 段落 向 右 对 齐 , 一 个 段落 居中 ,可 以 
先 定义 两 个 类 : 
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然后 用 在 不 同 的 段落 里 ,只 要 在 HTML 标记 里 加 入 自 定义 的 class 参数 ,如 : 


注意 : 类 的 名 称 可 以 是 任意 英文 单词 或 以 英文 开头 与 数字 的 组 合 ,一 般 以 其 功能 和 
效果 简要 命名 。 

类 选择 符 还 有 一 种 用 法 ,在 选择 符 中 省 略 HTML 标记 名 ,这 样 可 以 把 几 个 不 同 的 元 
素 定义 成 相同 的 样式 。 


(定义 . center 的 类 选择 符 为 文字 居中 排列 ) 
这 样 的 类 可 以 被 应 用 到 任何 元 素 上 。 下 面 使 hl 元 素 (标题 1) 和 p 元素 ( 段 落 ) 都 归 
为 center 类 ,这 使 两 个 元 素 的 样式 都 跟随 . center 这 个 类 选择 符 。 


注意 : 这 种 省 略 HTML 标记 的 类 选择 符 是 最 常用 的 CSS 方法 ,使 用 这 种 方法 可 以 
很 方便 地 在 任意 元 素 上 套用 预先 定义 好 的 类 样式 。 

4. ID 选择 符 

在 HTML 页 面 中 ID 参数 指定 了 某 个 单一 元 素 .ID 选择 符 是 用 来 对 这 个 单一 元 素 定 
义 单独 的 样式 。 

ID 选择 符 的 应 用 和 类 选择 符 类 似 , 只 要 把 CLASS 换 成 ID 即 可 。 将 上 例 中 类 用 ID 
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定义 ID 选择 符 要 在 ID 名 称 前 加 上 一 个 “#” 号 。 和 类 选择 符 相 同 , 定 义 ID 选择 符 的 
属性 也 有 两 种 方法 。 下 面 这 个 例子 ,ID 属性 将 匹配 所 有 id 一 "intro" 的 元 素 。 


(字体 尺寸 为 默认 尺寸 的 110% , 粗 体 , 蓝 色 ,背景 颜色 透明 ) 
下 面 这 个 例子 ,ID 属性 只 匹配 id= "intro" 的 段落 元 素 。 


注意 : ID 选择 符 局 限 性 很 大 ,只 能 单独 定义 某 个 元 素 的 样式 ,一 般 只 在 特殊 情况 下 
使 用 。 


5. 包含 选择 符 


可 以 单独 对 某 种 元 素 包含 关系 定义 的 样式 表 , 元 素 1 里 包含 元 素 2, 这 种 方式 只 对 在 
元 素 1 里 的 元 素 2 定义 ,对 单独 的 元 素 1 或 元 素 2 无 定义 .例如 : 


在 表格 内 的 链接 改变 了 样式 ,文字 大 小 为 12 像素 ,而 表格 外 链接 的 文字 仍 为 默认 
大 小 。 

6. 样式 表 的 层 倒 性 

层 全 性 就 是 继承 性 ,样式 表 的 继承 规则 是 外 部 的 元 素 样式 会 保留 下 来 继承 给 这 个 元 
素 所 包含 的 其 他 元 素 。 事 实 上 ,所 有 在 元 素 中 嵌 套 的 元 素 都 会 继承 外 层 元 素 指定 的 属性 
值 , 有 时 会 把 很 多 层 嵌 套 的 样式 和 琶 加 在 一 起 ,除非 另外 更 改 。 例 如 在 DIV 标记 中 肉 套 了 
标记 : 
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(P 元素 里 的 内 容 会 继承 DIV 定义 的 属性 ) 

注意 : 有 些 情况 下 内 部 选择 符 不 继承 周围 选择 符 的 值 ,但 理论 上 这 些 都 是 特殊 的 。 
例如 ,上 边界 属性 值 是 不 会 继承 的 ,一 个 段落 不 会 有 同文 档 BODY 一 样 的 上 边界 值 。 

另外 , 当 样 式 表 继 承 遇 到 冲突 时 ,总 是 以 最 后 定义 的 样式 为 准 。 如 果 上 例 中 定义 了 了 


可 以 看 到 段落 里 的 文字 大 小 为 9 号 字 , 是 继承 div 属性 的 ,而 color 属性 则 依照 最 后 
定义 的 。 

不 同 的 选择 符 定义 相同 的 元 素 时 ,要 考虑 到 不 同 选择 符 之 间 的 优先 级 。ID 选择 符 、 
类 选择 符 和 HTML 标记 选择 符 中 ,因为 ID 选择 符 是 最 后 加 在 元 素 上 的 ,所 以 优先 级 最 
高 ,其 次 是 类 选择 符 。 如 果 想 超越 这 三 者 之 间 的 关系 ,可 以 用 !important 提升 样式 表 的 优 
先 权 ,例如 : 


同时 对 页 面 中 的 一 个 段落 加 上 这 三 种 样式 , 它 最 后 会 依照 被 !important 申明 的 HT- 
ML 标记 选择 符 样式 为 红色 文字 。 如 果 去 掉 !important, 则 依照 优先 权 最 高 的 ID 选择 符 
为 黄色 文字 。 

7. 注释 


可 以 在 CSS 中 插入 注释 来 说 明代 码 的 意思 ,注释 有 利于 以 后 编辑 和 更 改 代码 时 理解 
代码 的 含义 。 在 浏览 器 中 ,注释 是 不 显示 的 。CSS 注释 以 */* ”开头 ,以 “x* /” 结 尾 ,如 下 : 
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font- family: arial /* 字体 为 arial * / 
1 


2.2.3 ”如 何在 网 页 中 插入 CSS 


前 面 了 解 了 CSS 的 语法 ,但 要 想 在 浏览 器 中 显示 出 效果 ,就 要 让 浏览 器 识别 并 调用 。 
当 浏 览 器 读 取样 式 表 时 ,要 依照 文本 格式 来 读 , 这 里 介绍 4 种 在 页 面 中 插入 样式 表 的 方 
法 : 链 入 外 部 样式 表 、 内 部 样式 表 、 导 入 外 部 样式 表 和 内 咀 样式 。 

1. 链 入 外 部 样式 表 

链 入 外 部 样式 表 是 把 样式 表 保存 为 一 个 样式 表 文 件 ,然后 在 页 面 中 用 过 link 二 标记 
链接 到 这 个 样式 表 文 件 , 这 个 二 link 记 标记 必须 放 到 页 面 的 二 head 放 区 内 ,如 下 : 


<head> 
<link rel="stylesheet" type= "text/css" href= "mystyle.css"> 
< /head> 


上 面 这 个 例子 表示 浏览 器 从 mystyle. css 文件 中 以 文档 格式 读 出 定义 的 样式 表 。rel 
一 "stylesheet" 是 指 在 页 面 中 使 用 这 个 外 部 的 样式 表 。type= "textycss" 是 指 文件 的 类 型 
是 样式 表 文 本 。href 王 "mystyle. css" 是 文件 所 在 的 位 置 。 

一 个 外 部 样式 表 文 件 可 以 应 用 于 多 个 页 面 。 当 改变 这 个 样式 表 文 件 时 ,所 有 页 面 的 
样式 都 随 之 而 改变 。 在 制作 大 量 相同 样式 页 面 的 网 站 时 , 它 非 常 有 用 ,不 仅 减 少 了 重复 的 
工作 量 ,而 且 有 利于 以 后 的 修改 、 编 辑 ,浏览 时 也 减少 了 重复 下 载 代码 。 

样式 表 文 件 可 以 用 任何 文本 编辑 器 (如 记事 本 ) 打 开 并 编辑 ,一般 样式 表 文 件 扩展 名 
为 .css。 内 容 是 定义 的 样式 表 , 不 包含 HTML 标记 。mystyle. css 文件 的 内 容 如 下 : 


hr {color: sienna} 
P {margin- left: 20px} 
body {background- image: url ("images/back40.gif")} 


(定义 水 平 线 的 颜色 为 土 黄 ; 段 落 左 边 的 空白 边 距 为 20 像素 ;页 面 的 背景 图 片 为 im- 
ages 目录 下 的 back40. gif 文件 ) 

2. 内 部 样式 表 

内 部 样式 表 是 把 样式 表 放 到 页 面 的 二 head 二 区 里 .这 些 定义 的 样式 就 应 用 到 页 面 中 
了 ,样式 表 是 用 二 style 二 标记 插入 的 ,从 下 例 中 可 以 看 出 二 style 二 标记 的 用 法 。 


<head> 
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注意 : 有 些 低 版 本 的 浏览 器 不 能 识别 style 标记 ,这 意味 着 低 版 本 的 浏览 器 会 忽略 
style 标记 里 的 内 容 , 并 把 style 标记 里 的 内 容 以 文本 直接 显示 到 页 面 上 。 为 了 避免 这 样 
的 情况 发 生 , 用 加 HTML 注释 的 方式 (所 ! 一 一 注释 一 一 盖 ) 隐 藏 内 容 而 不 让 它 显 示 。 


3. 导入 外 部 样式 表 


导 和 人 外 部 样式 表 是 指 在 内 部 样式 表 的 二 style 二 里 导入 一 个 外 部 样式 表 , 导 入 时 用 
@import。 看 下 面 这 个 实例 : 


例 中 @import "mystyle. css" 表 示 导 入 mystyle. css 样式 表 , 注 意 使 用 时 外 部 样式 表 
的 路 径 。 方 法 和 链 入 样式 表 的 方法 很 相似 ,但 导入 外 部 样式 表 输 入 方式 更 有 优势 。 实 质 
上 它 相当 于 存在 内 部 样式 表 中 的 。 
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注意 : 导入 外 部 样式 表 必 须 在 样式 表 的 开始 部 分 ,在 其 他 内 部 样式 表 上 面 。 

4. 内 嵌 样 式 

内 符 样 式 是 混合 在 HTML 标记 里 使 用 的 ,用 这 种 方法 ,可 以 很 简单 地 对 某 个 元 素 单 
独 定义 样式 。 内 骨 样 式 的 使 用 是 直接 在 HTML 标记 里 加 入 style 参数 。 而 style 参数 的 
内 容 就 是 CSS 的 属性 和 值 , 如 下 例 : 


(这 个 段落 颜色 为 土 黄 , 左 边 距 为 20 像素 ) 

在 style 参数 后 面 引号 里 的 内 容 相当 于 在 样式 表 大 括号 里 的 内 容 。 

注意 : style 参数 可 以 应 用 于 任意 BODY 内 的 元 素 (包括 BODY 本 身 ) ,除了 BASE- 
FONT、PARAM 和 SCRIPT。 

S. 多 重 样式 表 的 丢 加 

上 一 节 里 已 经 提 到 样式 表 的 层 全 顺序 ,已 经 讨论 择 入 样式 表 的 这 几 种 方法 的 全 加 。 
如 果 在 同一 个 选择 器 上 使 用 几 个 不 同 的 样式 表 时 ,这 个 属性 值 将 会 登 加 几 个 样式 表 , 过 到 
冲突 的 地 方 会 以 最 后 定义 的 为 准 。 例 如 ,首先 链 入 一 个 外 部 样式 表 , 其 中 定义 了 h3 选择 
符 的 color、text-align 和 font-size 属性 。 


(标题 3 的 文字 颜色 为 红色 ,向 左 对 齐 , 文 字 尺寸 为 8 号 字 ) 
然后 在 内 部 样式 表 里 也 定义 了 h3 选择 符 的 text-align 和 font-size 属性 。 


(标题 3 文字 向 右 对 齐 , 尺 寸 为 20 号 字 ) 
那么 这 个 页 面 琶 加 后 的 样式 就 是 : 


(文字 颜色 为 红色 ,向 右 对 齐 , 尺 寸 为 20 号 字 ) 
字体 颜色 从 外 部 样式 表 里 保留 下 来 ,而 对 齐 方式 和 字体 尺寸 都 有 定义 时 ,按照 后 定义 
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的 优先 而 依照 内 部 样式 表 。 
注意 : 依照 后 定义 的 优先 ,优先 级 最 高 的 是 内 崇 样 式 ,内 部 样式 表 高 于 导入 外 部 样式 
表 , 链 入 的 外 部 样式 表 和 内 部 样式 表 之 间 是 最 后 定义 的 优先 级 高 。 


2.3 JavaScript 语言 简介 


2.3.1 JavaScript 语言 概况 


1. 什么 是 JavaScript 

JavaScript 是 一 种 基于 对 象 (Object) 和 事件 驱动 (Event Driven) 并 具有 安全 性 能 的 
脚本 语言 。 使 用 它 的 目的 是 与 HTML、Java 脚本 语言 (Java 小 程序 ) 一 起 实现 在 一 个 
Web 页 面 中 链接 多 个 对 象 , 与 Web 客户 交互 作用 。 从 而 可 以 开发 客户 端的 应 用 程序 等 。 
它 是 通过 嵌入 或 调和 人 在 标准 的 HTML 语言 中 实现 的 。 它 的 出 现 弥补 了 HTML 语言 的 
缺陷 ,也 是 Java 与 HTML 折 中 的 选择 。 它 具有 以 下 几 个 基本 特点 。 

1) 脚本 语言 。 它 采用 小 程序 段 的 方式 实现 编程 。 像 其 他 脚本 语言 一 样 ,JavaScript 
同样 也 是 一 种 解释 性 语言 ,提供 了 一 个 易 开 发 的 过 程 。 它 的 基本 结构 形式 与 CC ++、VB 
和 Delphi 十 分 类 似 。 但 它 不 像 这 些 语 言 那样 需要 先 编译 ,而 是 在 程序 运行 过 程 中 被 逐 行 
地 解释 。 它 与 HTML 标识 结合 在 一 起 ,从 而 方便 用 户 的 使 用 操作 。 

2) 基于 对 象 的 语言 。JavaScript 是 一 种 基于 对 象 的 语言 ,同时 也 可 以 看 作 一 种 面向 
对 象 的 语言 。 这 意味 着 它 能 运用 自己 已 经 创建 的 对 象 。 因 此 ,许多 功能 可 以 来 自 于 脚本 
环境 中 对 象 的 方法 与 脚本 的 相互 作用 。 

3) 简单 性 。JavaScript 的 简单 性 主要 体现 在 : 首先 , 它 是 一 种 基于 Java 基本 语句 和 
控制 流 之 上 的 简单 而 紧凑 的 设计 , 从 而 对 于 学 习 Java 是 一 种 非常 好 的 过 渡 。 其 次 , 它 的 
变量 类 型 是 采用 弱 类 型 ,并 未 使 用 严格 的 数据 类 型 。 

4) 安全 性 。JavaScript 是 一 种 安全 性 语言 ,不 允许 访问 本 地 的 硬盘 ,并 不 能 将 数据 存 
入 到 服务 器 上 ,不 允许 对 网 络 文档 进行 修改 和 删除 ,只 能 通过 浏览 器 实现 信息 浏览 或 动态 
交互 ,从 而 有 效 地 防止 数据 的 丢失 。 

5) 动态 性 。JavaScript 是 动态 的 , 它 可 以 直接 对 用 户 或 客户 输入 做 出 响应 ,无 须 经 过 
Web 服务 程序 。 它 对 用 户 的 反应 响应 ,是 采用 以 事件 驱动 的 方式 进行 的 。 事 件 驱 动 ,就 
是 指 在 主页 (Home Page) 中 执行 了 某 种 操作 所 产生 的 动作 ,就 称 为 "事件 (Event)”。 例 如 
按 下 鼠标 、 移 动 窗 口 和 选择 菜单 等 都 可 以 视 为 事件 。 当 事件 发 生 后 ,可 能 会 引起 相应 的 事 
件 响应 。 

6) 跨 平台 性 。JavaScript 是 依赖 于 浏览 器 本 身 .与 操作 环境 无 关 , 只 要 能 运行 浏览 器 
的 计算 机 ,并 支持 JavaScript 的 浏览 器 就 可 正确 执行 。 从 而 实现 了 “编写 一 次 , 走 遍 天 下 ” 
的 梦想 。 

实际 上 JavaScript 最 杰出 之 处 在 于 可 以 用 很 小 的 程序 做 大 量 的 事 。 无 须 高 性 能 的 计 
算 机 , 仅 需 要 一 个 文字 处 理 软件 及 一 浏览 器 .无须 Web 服务 器 通道 ,通过 自己 的 计算 机 即 
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可 完成 所 有 的 事情 。 

综 上 所 述 ,JavaScript 是 一 种 新 的 描述 语言 , 它 可 以 被 内 入 到 HTML 的 文件 之 中 。 
JavaScript 语言 可 以 做 到 回应 使 用 者 的 需求 事件 (如 form 的 输入 ) ,而 不 用 任何 的 网 络 来 
回 传输 资料 。 所 以 当 一 位 使 用 者 输入 一 项 资料 时 , 它 不 用 经 过 传 给 伺服 端 处 理 再 传 回来 
的 过 程 ,而 直接 可 以 被 客户 端的 应 用 程式 所 处 理 。 

2. 编写 第 一 个 JavaScript 程序 

下 面 通过 一 个 例子 ,编写 第 一 个 JavaScript 程序 。 通 过 它 可 说 明 JavaScript 的 脚本 
是 怎样 被 嵌入 到 HTML 文档 中 的 。 


<html> 

<head> 

< Script Language= "JavaScript"> 

//JavaScript Appears here. 

alert ("这 是 第 一 个 Javascript 例子 !"); 

alert ("欢迎 你 进入 Javascript 世界 1"); 

alert ("今后 我 们 将 共同 学 习 Javascript 知识 !"); 
< /script> 

< /Head> 

</Html> 


在 Internet Explorer5. 0 中 运行 后 的 结果 如 图 2-2 所 示 。 

说 明 : test. html 是 HTML 文档 ,其 标识 
格式 为 标准 的 HTML 格式 。 如 同 HTML 标 
识 语言 一 样 ， JavaScript 程序 代码 是 一 些 可 用 
字 处 理 软件 浏览 的 文本 , 它 在 描述 页 面 的 HT- 
ML 相关 区 域 出 现 。JavaScript 代码 由 
< 一 Script Language 一 ”JavaScript ”二 … 
所 /Script 二 说 明 。 在 标识 二 Script Language 
三 "JavaScript" 二 … 王 /Script 二 之 间 就 可 加 入 


JavaScript 脚本 。 

alert() 是 JavaScript 的 窗口 对 象 方 法 ,其 2-2 程序 运行 的 结果 
功能 是 弹出 一 个 具有 OK 对 话 框 并 显示 () 中 
的 字符 串 。 通 过 过 ! 一 一 …// 一 一 > 标识 说 明 : 若 不 认识 JavaScript 代码 的 浏览 器 , 则 所 


有 在 其 中 的 标识 均 被 忽略 ; 若 认 识 , 则 执行 其 结果 。jJavaScript 以 二 /Script> 标签 结束 。 
2.3.2 JavaScript 基本 数据 结构 


JavaScript 提供 脚本 语言 的 编程 与 C++ 非 常 相似 , 它 只 是 去 掉 了 C 语言 中 有 关 指 针 
等 容易 产生 的 错误 .并 提供 了 功能 强大 的 类 库 。 对 于 已 经 具备 C++ 或 C 语言 的 人 来 说 ， 
学 习 JavaScript 脚本 语言 是 一 件 非常 轻松 愉快 的 事 。 
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1. JavaScript 代码 的 加 入 

JavaScript 的 脚本 包括 在 HTML 中 , 它 成 为 HTML 文档 的 一 部 分 。 与 HTML 标识 
相 结合 ,构成 了 一 个 功能 强大 的 Internet 网 上 编程 语言 。 可 以 直接 将 JavaScript 脚本 加 
入 文档 : 


< Script Language= "JavaScript"> 
JavaScript 语言 代码 ; 
JavaScript 语言 代码 ; 


</script> 


说 明 : 通过 标识 二 Script 二 …< 一 /Script 二 指明 JavaScript 脚本 源 代码 将 放 入 其 间 。 
通过 属性 Language 二 "JavaScript" 说 明 标 识 中 是 使 用 的 何 种 语言 ,这 里 是 JavaScript 语 
言 , 表示 在 JavaScript 中 使 用 的 语言 。 

下 面 是 将 JavaScript 脚本 加 入 Web 文档 中 的 例子 。 


<HITML> 

<Head> 

<Script Language= "JavaScript"> 
document. Write ("这 是 网 络 学 校 1"); 
document. close(); 

< /Script> 

< /Head> 

< /HIML> 


在 浏览 器 的 窗口 中 调用 test2. html, 则 显示 “这 是 网 络 学 校 !" 字 串 。 

说 明 : Document，write() 是 文档 对 象 的 输出 函数 ,其 功能 是 将 括号 中 的 字符 或 变量 
值 输出 到 窗口 ;document. close() 是 将 输出 关闭 。 可 将 二 Script 二 … 一 /Script 二 标识 放 
入 二 Head 二 …< 王 /Head 二 或 Body 二 …< 一 /Body 之 之 间 。 将 JavaScript 标识 放 和 人 
二 Head 二 … 二 /Head 二 之 间 , 使 之 在 主页 和 其 余部 分 代码 之 前 装载 ,从 而 可 使 代码 的 功 
能 更 强大 。 可 以 将 JavaScript 标识 放置 在 Body 二 … 三 /Body 二 主体 之 间 以 实现 某 些 部 
分 动态 地 创建 文档 。 

2. 基本 数据 类 型 

JavaScript 脚本 语言 同 其 他 语言 一 样 ,有 它 自 身 的 基本 数据 类 型 表达 式 和 算术 运算 
符 以 及 程序 的 基本 框架 结构 。JavaScript 提供 了 4 种 基本 的 数据 类 型 用 来 处 理 数字 和 文 
字 , 而 变量 提供 存放 信息 的 地 方 , 表达 式 则 可 以 完成 较 复杂 的 信息 处 理 。 

1) 基本 数据 类 型 

在 JavaScript 中 有 4 种 基本 的 数据 类 型 : 数值 (整数 和 实数 ) .字符 串 型 (用 ”" 或 ' 号 
括 起 来 的 字符 或 数值 ) .布尔 型 (用 True 或 False 表示 ) 和 空 值 。 在 JavaScript 的 基本 类 
型 中 ,数据 可 以 是 常量 ,也 可 以 是 变量 。 由 于 JavaScript 采用 弱 类 型 的 形式 ,因而 一 个 数 
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据 的 变量 或 常量 不 必 首 先 作 声明 ,而 是 在 使 用 或 赋值 时 确定 其 数据 的 类 型 。 当 然 , 也 可 以 
先 声明 该 数据 的 类 型 . 它 是 通过 在 赋值 时 自动 说 明 其 数据 类 型 的 。 


2) 


3) 


常量 

整 型 常量 ; JavaScript 的 常量 通常 又 称 字 面 常量 , 它 是 不 能 改变 的 数据 。 其 整 型 
常量 可 以 使 用 十 六 进 制 八 进 制 和 十 进 制 表示 其 值 。 

实 型 常量 : 由 整数 部 分 加 小 数 部 分 表示 ,如 12. 32、193. 98 等 。 可 以 使 用 科学 或 标 
准 方法 表示 ,如 5E7、4e5 等 。 

布尔 值 : 布尔 常量 只 有 True 和 False 两 种 状态 。 它 主要 用 来 说 明 或 代表 一 种 状 
态 或 标志 ,以 说 明 操 作 流 程 。 它 与 C++ 是 不 一 样 的 ,C++ 可 以 用 1 或 0 表示 其 状 
态 , 而 JavaScript 只 能 用 True 或 False 表示 其 状态 。 

字符 型 常量 : 使 用 单 引 号 (7 或 双 引 号 (") 括 起 来 的 一 个 或 几 个 字符 。 如 "This is a 
book of JavaScript"、"3245" 和 "ewrt234234" 等 。 

空 值 : JavaScript 中 有 一 个 空 值 null, 表 示 什 么 也 没有 。 如 试图 引用 没有 定义 的 
变量 , 则 返回 一 个 Null 值 。 

特殊 字符 : 同 C 语言 一 样 ,JavaSeript 中 同样 有 些 以 反 斜 杜 (/) 开 头 的 不 可 显示 的 
特殊 字符 。 通 常 称 为 控制 字符 。 


变量 的 主要 作用 是 存 取 数据 、 提 供 存放 信息 的 容器 。 对 于 变量 必须 明确 变量 的 命名 、 
变量 的 类 型 .变量 的 声明 及 其 作用 域 。 

(1) 变量 的 命名 。 

JavaScript 中 的 变量 命名 同 其 计算 机 语言 非常 相似 ,这 里 要 注意 以 下 两 点 。 


必须 是 一 个 有 效 的 变量 , 即 变量 以 字母 开头 ,中 间 可 以 出 现 数字 如 testl、 text2 
等 。 除 下 划 线 (_) 作 为 连 字 符 外 ,变量 名 称 不 能 有 空格 “十 ”、“ 一 ”"“," 或 其 他 
符号 。 

不 能 使 用 JavaScript 中 的 关键 字 作 为 变量 。 


在 JavaScript 中 定义 了 40 多 个 关键 字 , 这 些 关 键 字 是 JavaScript 内 部 使 用 的 ,不 能 
作为 变量 的 名 称 。 如 Var、int、double 和 true 不 能 作为 变量 的 名 称 。 

在 对 变量 命名 时 ,最 好 把 变量 的 意义 与 其 代表 的 意思 对 应 起 来 ,以 免 出 现 错误 。 

(2) 变量 的 类 型 。 

在 JavaScript 中 ,变量 可 以 用 命令 Var 作 声明 : Var mytest; 。 

该 例子 定义 了 一 个 mytest 变量 ,但 没有 赋予 它 的 值 。 


Var mytest= "This is a book”" 

该 例子 定义 了 一 个 mytest 变量 ,同时 赋予 了 它 的 值 。 

在 JavaScript 中 ,变量 可 以 不 作 声明 ,而 在 使 用 时 再 根据 数据 的 类 型 来 确定 变量 的 类 型 。 
如 : 


x=100 
中 "125” 
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xy= True 
cost=19.5 


其 中 x 为 整数 ,y 为 字符 串 ,xy 为 布尔 型 .cost 为 实 型 。 

(3) 变量 的 声明 及 其 作用 域 。 

JavaScript 变量 可 以 在 使 用 前 先 作 声明 ,并 可 赋值 。 通 过 使 用 var 关键 字 对 变量 作 声 
明 。 对 变量 作 声明 的 最 大 好 处 就 是 能 及 时 发 现代 码 中 的 错误 ,因为 JavaScript 是 采用 动 
态 编译 的 ,而 动态 编译 是 不 易 发 现代 码 中 的 错误 ,特别 是 变量 命名 方面 。 

对 于 变量 还 有 一 个 重要 性 一 一 变量 的 作用 域 。 在 JavaScript 中 同样 有 全 局 变量 和 局 
部 变量 。 全 局 变量 是 定义 在 所 有 函数 体 之 外 ,其 作用 范围 是 整个 函数 ;而 局 部 变量 是 定义 
在 函数 体 之 内 ,只 对 该 函数 是 可 见 的 ,而 对 其 他 函数 则 是 不 可 见 的 。 

3. 表达 式 和 运算 符 

1) 表达 式 

在 定义 完 变 量 后 ,就 可 以 对 它们 进行 赋值 ,改变 和 计算 等 一 系列 操作 ,这 一 过 程 通常 
由 表达 式 完成 。 表 达 式 是 变量 .常量 ,布尔 及 运算 符 的 集合 ,因此 表达 式 可 以 分 为 算术 表 
达 式 、 字 串 表 达 式 、 赋 值 表 达 式 及 布尔 表达 式 等 。 

2) 运算 符 

运算 符 完成 操作 的 一 系列 符号 ,在 JavaScript 中 有 算术 运算 符 , 如 十 一、* /等 ;有 
比较 运算 符 , 如 != .= 三 等 ;有 布尔 逻辑 运算 符 , 如 !( 取 反 )、|、|| 等 ; 有 字 串 运算 符 , 如 
十 ,十 = 等 。 

在 JavaScript 中 主要 有 双 目 运算 符 和 单 目 运算 符 。 其 双 目 运算 符 由 下 列 组 成 : 

操作 数 1 运算 符 操作 数 2 

即 由 两 个 操作 数 和 一 个 运算 符 组 成 ,如 50 十 40、"This" 十 "that" 等 。 单 日 运算 符 ,只 
需 一 个 操作 数 , 其 运算 符 可 在 前 或 后 。 

(1) 算术 运算 符 。 

JavaScript 中 的 算术 运算 符 有 单 目 运算 符 和 双 目 运算 符 。 

。 双 目 运算 符 : 十 (加 )、 一 ( 减 )、* ( 乘 )、/( 除 )、%( 取 模 ) 、| ( 按 位 或 )、&( 按 位 

与 )<<<<( 左 移 )、>>( 右 移 ) 和 之 之 >( 右 移 ,0 填充 )。 

。 单 目 运算 符 : 一 ( 取 反 )、 一 ( 取 补 )、 十 十 ( 递 加 1) 和 一 一 (递减 1) 。 

(2) 比较 运算 符 。 

比较 运算 符 的 基本 操作 过 程 是 ,首先 对 它 的 操作 数 进行 比较 ,然后 再 返回 一 个 True 
或 False 值 。 有 如 下 6 个 比较 运算 符 。 

去 (小 于 ) .>( 大 于 )、 雪 一 (小 于 等 于 )、 > 一 (大 于 等 于 ) .一 一 (等 于 )、! 王 (不 等 于 ) 

(3) 布尔 逻辑 运算 符 。 

在 JavaScript 中 增加 了 几 个 布尔 逻辑 运算 符 。 

1!( 取 反 )、 咏 二 (与 之 后 赋值 )、& (逻辑 与 )、| 二 (或 之 后 赋值 )、| (逻辑 或 )、^ 王 ( 异 或 
之 后 赋值 )、^( 逻 辑 异 或 )、?:( 三 目 操作 符 )、| | (或 ) .= 一 (等 于 ) 和 ! 一 (不 等 于 ) 

其 中 三 目 操 作 符 主要 格式 如 下 : 
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操作 数 ? 结 果 1: 结果 2 

若 操作 数 的 结果 为 真 , 则 表达 式 的 结果 为 结果 1 ,否则 为 结果 2。 
3) 范例 

下 面 是 一 个 跑马 灯 效 果 的 JavaScript 文档 。 


上 面 介 绍 了 JavaScript 脚本 是 如 何 加 入 Web 页 面 ,并 学 习 了 JavaScript 语言 中 的 基 
本 数据 类 型 .变量 .常量 和 操作 运算 符 等 。 
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2.3.3 JavaScript 程序 构成 


JavaScript 脚本 语言 的 基本 构成 包括 控制 语句 、 函 数 、 对 象 ,方法 和 属性 等 ,并 由 这 些 
基本 构成 来 实现 编程 。 

1. 程序 控制 流 

在 任何 一 种 语言 中 ,程序 控制 流 是 必需 的 , 它 能 使 得 整个 程序 减 小 混乱 ,使 之 顺利 按 
其 一 定 的 方式 执行 。 下 面 是 JavaScript 常用 的 程序 控制 流 结构 及 语句 。 

1) 让 条 件 语 句 

基本 格式 : 


功能 : 若 表达 式 为 true, 则 执行 语句 段 1; 和 否则 执行 语句 段 2。 

说 明 : 

(1) ifelse 语句 是 JavaScript 中 最 基本 的 控制 语句 ,通过 它 可 以 改变 语句 的 执行 顺序 。 
(2) 表达 式 中 必须 使 用 关系 语句 来 实现 判断 , 它 是 作为 一 个 布尔 值 来 估算 的 。 

(3) 它 将 0 和 非 0 的 数 分 别 转化 成 false 和 true。 

(4) 若 让 后 的 语句 有 多 行 , 则 必须 使 用 花 括 号 将 其 括 起 来 。 

让 语 句 的 柑 套 : 


在 这 种 情况 下 ,每 一 级 的 布尔 表达 式 都 会 被 计算 , 若 为 真 , 则 执行 其 相应 的 语句 ,否则 
执行 else 后 的 语句 。 

2) For 循环 语句 

基本 格式 : 


功能 : 实现 条 件 循环 , 当 条 件 成 立时 ,执行 语句 集 ,否则 跳出 循环 体 。 
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说 明 : 

(1) 初始 化 参数 告诉 循环 的 开始 位 置 ,必须 赋予 变量 的 初 值 。 

(2) 条 件 : 用 于 判别 循环 停止 时 的 条 件 。 若 条 件 满足 , 则 执行 循环 体 ,否则 跳出 。 
(3) 增 量 : 主要 定义 循环 控制 变量 在 每 次 循环 时 按 什么 方式 变化 。 

(4) 三 个 主要 语句 之 间 ,必须 使 用 逗号 分 隔 。 

3) while 循环 

基本 格式 : 


while (条件 ) 
语句 集 ; 


该 语句 与 For 语句 一 样 , 当 条 件 为 真 时 重复 循环 ,否则 退出 循环 。 

For 与 while 语句 都 是 循环 语句 ,使 用 For 语句 在 处 理 有 关 数 字 时 更 易 看 懂 , 也 较 紧 
次 ;而 while 循环 对 复杂 的 语句 效果 更 特别 。 

4) break 和 continue 语句 

与 C++ 语言 相同 ,使 用 break 语句 使 得 循环 从 For 或 while 中 跳出 ,continue 使 得 跳 
过 循环 内 剩余 的 语句 而 进入 下 一 次 循环 。 

2. 函数 

函数 为 程序 设计 人 员 提 供 了 一 个 非常 方便 的 能 力 。 通 常 在 进行 一 个 复杂 的 程序 设计 
时 ,总 是 根据 所 要 完成 的 功能 ,将 程序 划分 为 一 些 相 对 独立 的 部 分 ,每 部 分 编写 一 个 函数 。 
从 而 使 各 部 分 充分 独立 ,任务 单一 ,程序 清晰 , 易 懂 、 易 读 、 易 维护 。JavaScript 函数 可 以 
封装 那些 在 程序 中 可 能 要 多 次 用 到 的 模块 ,并 可 作为 事件 驱动 的 结果 而 调用 的 程序 。 从 
而 实现 一 个 函数 把 它 与 事件 驱动 相关 联 。 这 是 与 其 他 语言 不 一 样 的 地 方 。 

1) JavaScript 函数 定义 


Function 函数 名 (参数 , 变 元 ) { 


说 明 : 

当 调用 函数 时 ,所 用 变量 或 字面 量 均 可 作为 变 元 传递 。 函 数 由 关键 字 Function 定 
义 。 函 数 名 ,定义 自己 函数 的 名 字 。 参 数 表 , 是 传递 给 函数 使 用 或 操作 的 值 ,其 值 可 以 是 
常量 、 变 量 或 其 他 表达 式 。 通 过 指定 函数 名 ( 实 参 ) 来 调用 一 个 函数 ,必须 使 用 Return 将 
值 返 回 。 函 数 名 对 大 小 写 是 敏感 的 。 

2) 函数 中 的 形式 参数 

在 函数 的 定义 中 ,我 们 看 到 函数 名 后 有 参数 表 , 这 些 参 数 变量 可 能 是 一 个 或 几 个 。 那 
么 怎样 才能 确定 参数 变量 的 个 数 呢 ? 在 JavaScript 中 可 通过 arguments . Length 来 检查 
参数 的 个 数 。 例 如 : 
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3. 事件 驱动 及 事件 处 理 

1) 基本 概念 

JavaScript 是 基于 对 象 (object-based) 的 语言 。 这 与 Java 不 同 ,Java 是 面向 对 象 的 语 
言 。 而 基于 对 象 的 基本 特征 ,就 是 采用 事件 驱动 (event-driven)。 它 是 在 图 形 界面 的 环境 
下 ,使 得 一 切 输入 变 得 简单 化 。 通 常 鼠 标 或 热 键 的 动作 称 为 事件 ,而 由 鼠标 或 热 键 引 发 的 
一 连 串 程序 的 动作 , 称 为 事件 驱动 。 而 对 事件 进行 处 理 程 序 或 函数 , 称 为 事件 处 理 程序 
(Event Handler) 。 

2) 事件 处 理 程序 

在 JavaScript 中 对 象 事件 的 处 理 通常 由 函数 (Function) 担 任 。 其 基本 格式 与 函数 全 
部 一 样 ,可 以 将 前 面 所 介绍 的 所 有 函数 作为 事件 处 理 程序 。 格 式 如 下 : 


3) 事件 驱动 

JavaScript 事件 驱动 中 的 事件 是 通过 鼠标 或 热 键 的 动作 引发 的 。 它 主要 有 以 下 几 个 
事件 。 

(1) 单 击 事件 onClick。 

当 用 户 单 击 鼠 标 按钮 时 ,产生 onClick 事件 。 同 时 onClick 指定 的 事件 处 理 程序 或 代 
码 将 被 调用 执行 。 通 常 在 下 列 基本 对 象 中 产生 。 

。 button( 按 钮 对 象 ) 

， checkbox( 复 选 框 ) 或 (检查 列表 框 ) 

。 radio ( 单 选 按 钮 ) 

。 reset buttons( 重 要 按钮 ) 

。 submit buttons( 提 交 按钮 ) 

例如 ,可 通过 下 列 按钮 激活 change() 文 件 。 
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在 onClick 等 号 后 ,可 以 使 用 自己 编写 的 函数 作为 事件 处 理 程序 ,也 可 以 使 用 JavaS- 
cript 中 内 部 的 函数 。 还 可 以 直接 使 用 JavaScript 的 代码 等 。 例 如 : 


(2) onChange 改变 事件 。 
当 利用 text 或 textarea 元 素 输入 字符 值 改 变 时 引发 该 事件 ,同时 当 在 select 表格 项 
中 一 个 选项 状态 改变 后 也 会 引发 该 事件 。 例 如 : 


(3) 选中 事件 onSelect。 

当 text 或 textarea 对 象 中 的 文字 被 加 亮 后 ,引发 该 事件 。 

(4) 获得 焦点 事件 onFocus。 

当 用 户 单 击 text 或 textarea 及 select 对 象 时 产生 该 事件 。 此 时 该 对 象 成 为 前 台 
对 象 。 

(5) 失去 焦点 onBlur。 

当 text 对 象 或 textarea 对 象 及 select 对 象 不 再 拥有 焦点 而 退 到 后 台 时 ,引发 该 文件 ， 
它 与 onFocus 事件 是 一 个 对 应 的 关系 。 

(6) 载 人 文件 onLoad。 

当 文档 载 入 时 ,产生 该 事件 。onLoad 的 一 个 作用 就 是 在 首次 载 入 一 个 文档 时 检测 
cookie 的 值 ,并 用 一 个 变量 为 其 赋值 .使 它 可 以 被 源 代码 使 用 。 

(7) 印 载 文件 onUnload。 

当 Web 页 面 退 出 时 引发 onUnload 事件 ,并 可 更 新 Cookie 的 状态 。 

4. 范例 

范例 1: 下 例 程序 是 一 个 自动 装载 和 自动 印 载 的 例子 。 即 在 装 入 HTML 文档 时 调 
用 loadform() 函 数 , 而 退出 该 文档 进入 另 一 个 HTML 文档 时 则 首先 调用 unloadform 函 
数 , 确 认 后 方 可 进入 。 
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范例 2: 这 是 一 个 获取 浏览 器 版 本 号 的 程序 。 该 程序 首先 显示 一 个 波浪 , 即 提示 信 
息 。 之 后 显示 浏览 器 的 版 本 号 有 关 信 息 。 
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</script> 
<body> 
</body> 
</htm> 


输出 结果 如 图 2-3 所 示 。 


浏览 器 名 称 : Mi crosoft Internet Explorer 

版 本 号 : 4.0 (compatible; MSIE 5. Obl; Windows 98) 

代码 名 字 : Mozilla 

用 户 代理 标识 : Mozilla/4.0 (compatible; MSIE 5. 0bl; 

贴 ndows 98) 国 


图 2-3 输出 结果 


上 面 介绍 了 JavaScript 程序 设计 的 有 关内 容 。 程序 流 、 函 数 和 事件 是 学 习 掌 握 
JavaScript 编程 的 重点 。 


2.3.4 窗口 及 输入 输出 


JavaScript 是 基于 对 象 的 脚本 编程 语言 .其 输入 输出 就 是 通过 对 象 来 完成 的 。 其 中 
有 关 输 入 可 通过 窗口 对 象 来 完成 ,而 输出 可 通过 文档 对 象 的 方法 来 实现 。 

1. 窗口 及 输入 输出 

请 看 下 面 例子 : 


<HIML> 
<Head> 

<script languaga= "JavaScript"> 

Var test=window.prompt ("请 输入 数据 :"); 
document .write (test+ "Javascript 输入 输出 的 例子 "); 
</script> 

< /Head> 

< /HIML> 


其 中 window. prompt() 是 一 个 窗口 对 象 的 方法 。 其 基本 作用 是 当 装 人 Web 页 面 时 
在 屏幕 上 显示 一 个 具有 “确定 ”和 “取消 ”按钮 的 对 话 框 ,让 输出 数据 。document. write 是 
一 个 文档 对 象 的 方法 , 它 的 基本 功能 是 实现 Web 页 面 的 输出 显示 ,如 图 2-4 所 示 。 
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图 2-4 Web 页 的 输出 显示 


1) 窗口 对 象 

该 对 象 包括 许 多 有 用 的 属性 ,方法 和 事件 驱动 程序 .编程 人 员 可 以 利用 这 些 对 象 控制 
浏览 器 ,窗口 显示 的 各 个 方面 ,如 对 话 框 框架 等 。 在 使 用 时 应 注意 以 下 几 点 。 

该 对 象 对 应 于 HTML 文档 中 的 二 Body 二 和 二 FrameSet 二 两 种 标识 。 

onload 和 onunload 都 是 窗口 对 象 属性 ,在 JavaScript 脚本 中 可 直接 引用 窗口 对 象 。 
如 window. alert(" 窗 口 对 象 输入 方法 ") 可 直接 使 用 以 下 格式 : alert(" 窗 口 对 象 输入 方 
法 ")。 

2) 窗口 对 象 的 事件 驱动 

窗口 对 象 主要 有 装 和 人 Web 文档 事件 onload 和 和 印 载 时 的 onunload 事件 。 用 于 文档 载 
入 和 停止 载 入 时 开始 和 停止 更 新 文档 。 

3) 窗口 对 象 的 方法 

窗口 对 象 的 方法 主要 用 来 提供 信息 或 输入 数据 以 及 创建 一 个 新 的 窗口 。 

(1) 创建 一 个 新 窗口 。 使 用 window. open( 参 数 表 ) 方 法 可 以 创建 一 个 新 的 窗口 。 其 
中 参数 表 提 供 有 窗口 的 主要 特性 和 文档 及 窗口 的 命名 。 

(2) 创建 具有 OK 按钮 的 对 话 框 。alert 方法 能 创建 一 个 具有 OK 按钮 的 对 话 框 。 

(3) 创建 具有 OK 和 Cancel 按钮 的 对 话 框 。confirm 方法 为 编程 人 员 提 供 一 个 具有 
两 个 按钮 的 对 话 框 。 

(4) 创建 具有 输入 信息 的 对 话 框 。prompt 方法 允许 用 户 在 对 话 框 中 输入 信息 ,并 可 
使 用 默认 值 , 其 基本 格式 如 prompt(" 提 示 信 息 " ,默认 值 ) 。 

4) 窗口 对 象 中 的 属性 

窗口 对 象 中 的 属性 主要 用 来 对 浏览 器 中 存在 的 各 种 窗口 和 框架 的 引用 ,主要 属性 有 
以 下 几 个 。 

(1) frames: 确定 文档 中 帧 的 数目 。 

frames( 帧 ) 作 为 实现 一 个 窗口 的 分 隔 操作 起 到 非常 重要 的 作用 ,在 使 用 时 应 注意 ， 
frames 属性 是 通过 HTML 标识 二 Frames 过 的 顺序 来 引用 的 , 它 包 含 了 一 个 窗口 中 的 全 
部 帧 数 。 帧 本 身 已 是 一 类 窗口 ,继承 了 窗口 对 象 所 有 的 属性 和 方法 。 

(2) Parent: 指明 当前 窗口 或 帧 的 父 窗口 。 

(3) defaultstatus: 默认 状态 , 它 的 值 显 示 在 窗口 的 状态 栏 中 。 

(4) status: 包含 文档 窗口 中 帧 中 的 当前 信息 。 

(5) top: 包括 用 以 实现 所 有 下 级 窗口 的 窗口 。 

(6) window: 指 的 是 当前 窗口 。 

(7) self: 引用 当前 窗口 。 
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5) 输出 流 及 文档 对 象 

在 JavaScript 文档 对 象 中 ,提供 了 用 于 显示 关闭 .消除 .打开 HTML 页 面 的 输出 流 。 

(1) 创建 新 文档 open 方法 。 

使 用 document. open 创建 一 个 新 的 窗口 或 在 指定 的 命令 窗口 内 打开 文档 。 巾 于 窗 
口 对 象 是 所 加 载 的 父 对 象 , 因 而 在 调用 它 的 属性 或 方法 时 不 需要 加 入 Window 对 象 。 例 
如 ,用 Window. open 与 open 是 一 样 的 。 打 开 一 个 窗口 的 基本 格式 : 


Window .open ("URL", "窗口 名 称 ", "窗口 属性 ") 


window 属性 参数 是 一 个 字符 串 列表 项 , 它 由 逗号 分 隔 , 它 指明 了 有 关 新 创建 窗口 的 
属性 ,如 表 2-46 所 示 。 
表 2-46 新 创建 窗口 的 属性 参数 


参数 设 定 值 洛 一 党 
toolbar yes/no 建立 或 不 建立 标准 工具 条 
location yes/no 建立 或 不 建立 位 置 输入 字段 
directions yes/no 建立 或 不 建立 标准 目录 按钮 
status yes/no 建立 或 不 建立 状态 条 
menubar yes/no 建立 或 不 建立 菜单 条 
scrollbar yes/no 建立 或 不 建立 滚动 条 
revisable yes/no 能 否 改变 窗口 大 小 

width yes/no 确定 窗口 的 宽度 

height yes/no 确定 窗口 的 高 度 


在 使 用 open 方法 时 ,需要 注意 以 下 几 点 。 

O@ 通常 浏览 器 窗口 中 ,总 有 一 个 文档 是 打开 的 。 因 而 不 需要 为 输出 建立 一 个 新 
文档 。 

@ 在 完成 对 Web 文档 的 写 操作 后 ,要 使 用 或 调用 close 方法 来 实现 对 输出 流 的 
关闭 。 

@ 在 使 用 open 来 打开 一 个 新 流 时 ,可 为 文档 指定 一 个 有 效 的 文档 类 型 ,有 效 文档 类 
型 包括 text/HTML ,text/gif text/xim 和 text/plugin 等 。 

(2) write、writeln 输出 显示 。 

该 方法 主要 用 来 实现 在 Web 页 面 上 显示 输出 信息 。 在 实际 使 用 中 , 需 注意 以 下 
几 点 。 

。 writeln 与 write 唯一 不 同 之 处 在 于 在 末尾 加 了 一 个 换行 符 。 

。 为 了 正常 显示 其 输出 信息 .必须 指明 二 Pre 二 二 /Pre 二 标记 .使 之 告诉 编辑 器 。 

。 输出 的 文档 类 型 ,可 以 由 浏览 器 中 有 效 的 合法 文本 类 型 所 确定 。 

(3) 关闭 文档 流 close。 

在 实现 多 个 文档 对 象 中 ,必须 使 用 close 来 关闭 一 个 对 象 后 ,才能 打开 另 一 个 文档 
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对 象 。 

(4) 清除 文档 内 容 clear。 

使 用 该 方法 可 清除 已 经 打开 的 文档 内 容 。 

2. 简单 的 输入 、 输 出 例子 

在 JavaScript 中 可 以 非常 方便 地 实现 输入 输出 信息 ,并 与 用 户 进行 交互 。 

1) JavaScript 信息 的 输入 

通过 使 用 JavaScript 中 所 提供 的 窗口 对 象 方法 prompt, 就 能 完成 信息 的 输入 。 该 方 
法 提供 了 最 简便 的 信息 输入 方式 ,其 基本 格式 如 下 : 


Window.prompt (" 提 示 信 息 "， 预定 输入 信息 ); 


此 方法 首先 在 浏览 器 窗口 中 弹出 一 个 对 话 框 , 让 用 户 自行 输入 信息 。 一 旦 输入 完成 
后 ,就 返回 用 户 所 输入 信息 的 值 。 例 如 : 


test=prompt ("请 输入 数据 :", "this is a JavaScript"); 


实际 上 prompt 是 窗口 对 象 的 一 个 方法 。 因 为 默认 情况 下 所 用 的 对 象 就 是 window 
对 象 , 所 以 windows 对 象 可 以 省 略 不 写 。 

2) 输出 显示 

每 种 语言 ,都 必须 提供 信息 数据 的 输出 显示 。JavaScript 也 一 样 , 它 提供 了 几 个 用 于 
信息 输出 显示 的 方法 。 比 较 常 用 的 有 window. alert、document. write 和 document. writln 
方法 。 

(1) document. write 和 document. writeln 方法 。 

document 是 JavaScript 中 的 一 个 对 象 , 在 其 中 封装 了 许多 有 用 的 方法 ,其 中 write 和 
writeln 就 是 用 于 将 文本 信息 直接 输出 到 浏览 器 窗口 中 的 方法 。 


document .write () ;document .writeln(); 


说 明 : write 和 writeln 方法 都 是 用 于 向 浏览 器 窗口 输出 文本 字 串 ;二 者 的 唯一 区 别 
就 是 writeln 方法 自动 在 文本 之 后 加 入 回 车 符 。 

(2) window. alert 输出 。 

在 JavaScript 中 为 了 方便 信息 输出 ,JavaScript 提供 了 具有 独立 的 对 话 框 信 息 输 
出 alert 方法 。alert 方法 是 window 对 象 的 一 个 方法 ,因此 在 使 用 时 ,不 需要 写 win- 
dow 窗口 对 象 名 ,而 是 直接 使 用 就 行 了 。 它 的 主要 用 途 在 于 输出 时 产生 有 关 警 告 提示 信 
息 或 提示 用 户 , 只 有 用 户 单 击 “ 确 定 ” 按 钮 后 , 方 可 继续 执行 其 他 脚本 程序 。 例 如 : 


<HIML> 
<HEAD> 

<TITLIE>< /TITIE> 

< /HEAD> 

<BODY> 

< Script Language= "JavaScript"> 

alert ("这 是 一 个 uavascript 测试 程序 "); 
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(3) 利用 输入 、 输 出 方法 实现 交互 。 
在 JavaScript 中 ,可 以 利用 prompt 和 write 方法 实现 与 Web 页 面 用 户 进行 交互 。 下 
面 就 是 一 个 有 关 实 现 交互 的 例子 。 


从 上 面 程序 可 以 看 出 ,可 通过 write 和 prompt 方法 实现 交互 。 

在 JavaScript 脚本 语言 中 ,可 以 使 用 HTML 标识 语言 的 代码 ,从 而 实现 混合 编程 。 
其 中 二 HI 二 和 二 Br 就 是 HTML 标识 符 。 

(4) 范例 。 

下 列 程序 演示 了 进入 主页 所 停留 的 时 间 。 
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在 浏览 器 中 的 结果 如 图 2-5 所 示 。 


图 2-5 程序 运行 结果 


2.3.5 Web 页面 信息 的 交互 


要 实现 动态 交互 ,必须 掌握 有 关 窗 体 对 象 (Form) 和 框架 对 象 (Frames) 更 为 复杂 的 
知识 。 


1. 窗 体 基础 知识 


窗 体 对 象 可 以 使 设计 人 员 用 窗 体 中 不 同 的 元 素 与 客户 机 用 户 相 交互 ,而 用 不 着 在 之 
前 首先 进行 数据 输入 ,就 可 以 实现 动态 改变 Web 文档 的 行为 。 

1) 什么 是 窗 体 对 象 

窗 体 构成 了 Web 页 面 的 基本 元 素 。 通 常 Web 页 面 有 一 个 窗 体 或 几 个 窗 体 ,使 用 
Forms[ ] 数 组 来 实现 不 同窗 体 的 访问 。 
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在 Forms[0] 中 共有 三 个 基本 元 素 ,而 Forms[1] 中 只 有 两 个 元 素 。 
窗 体 对 象 最 主要 的 功能 就 是 能 够 直接 访问 HTML 文档 中 的 窗 体 , 它 封装 了 相关 的 
HTML 代码 。 


2) 窗 体 对 象 的 方法 
窗 体 对 象 的 方法 只 有 一 个 一 一 submit 方法 ,该 方法 的 主要 功能 是 实现 窗 体 信息 的 提 
交 。 如 提交 Mytest 窗 体 , 则 使 用 下 列 格式 : 


document .mytest.submit () 


3) 窗 体 对 象 的 属性 

窗 体 对 象 的 属性 主要 包括 elements ,name \action target .encoding 和 method。 

除 elements 外 ,其 他 几 个 均 反 映 了 窗 体 的 标识 中 相应 属性 的 状态 ,这 通常 是 单个 窗 
体 标 识 ; 而 elements 常常 是 多 个 窗 体 元 素 值 的 数组 。 例 如 : 


elements[0] .Mytable.elements[1] 


4) 访问 窗 体 对 象 

在 JavaScript 中 访问 窗 体 对 象 可 由 以 下 两 种 方法 实现 。 

(1) 通过 访问 窗 体 。 

在 窗 体 对 象 的 属性 中 首先 必须 指定 其 窗 体 名 ,而 后 就 可 以 通过 下 列 标识 访问 窗 体 ,如 
document. Mytable() 。 

(2) 通过 数组 来 访问 窗 体 。 

除了 使 用 窗 体 名 来 访问 窗 体外 ,还 可 以 使 用 窗 体 对 象 数 组 来 访问 窗 体 对 象 。 但 需要 
注意 一 点 , 因 窗 体 对 象 是 由 浏览 器 的 环境 提供 的 ,而 浏览 器 环境 所 提供 的 数组 下 标 是 0 一 
n, 所 以 可 通过 下 列 格式 实现 窗 体 对 象 的 访问 : 


document .forms [0] ;document .forms [1] ;document .forms [2]… 


5) 引用 窗 体 的 先决 条 件 
在 JavaScript 中 要 对 窗 体 引用 的 条 件 是 ,必须 先 在 页 面 中 用 标识 创建 窗 体 ,并 将 定义 


网 站 建设 实用 教程 


窗 体 部 分 放 在 引用 之 前 。 

2. 窗 体 中 的 基本 元 素 

窗 体 中 的 基本 元 素 由 按钮 、 单 选 按钮 . 复 选 按钮 .提交 按钮 、 重 置 按钮 和 文本 框 等 组 
成 。 在 JavaScript 中 要 访问 这 些 基 本 元 素 , 必 须 通过 对 应 特定 的 窗 体 元 素 的 数组 下 标 或 
窗 体 元 素 名 来 实现 。 每 一 个 元 素 主要 是 通过 该 元 素 的 属性 或 方法 来 引用 。 其 引用 的 基本 
格式 如 下 : 


formName .elements[] .methadName ( 窗 体 名 .元 素 名 或 数组 .方法 ) 
formName.element [] .propertyName ( 窗 体 名 .元 素 名 或 数组 .属性 ) 


下 面 分 别 介绍 。 

1) Text( 单 行 单列 输入 元 素 ) 

功能 : 对 Text 标识 中 的 元 素 实施 有 效 的 控制 。 

属性 。 

。， Name: 设 定 提交 信息 时 的 信息 名 称 。 对 应 于 HTML 文档 中 的 Name。 
"Value: 用 以 设 定 出 现在 窗口 中 对 应 HTML 文档 中 Value 的 信息 。 
。 defaultvalue: 包括 Text 元 素 的 默认 值 。 

方法 

blur: 将 当前 焦点 移 到 后 台 。 

select: 加 亮 文 字 。 

事件 。 

onFocus: 当 Text 获得 焦点 时 ,产生 该 事件 。 

OnBlur: 从 元 素 失 去 焦点 时 ,产生 该 事件 。 

Onselect: 当 文 字 被 加 亮 显 示 后 ,产生 该 文件 。 

onchange: 当 Text 元 素 值 改变 时 ,产生 该 文件 。 

例如 : 


2) textarea( 多 行 多 列 输入 元 素 ) 

功能 : 实施 对 Textarea 中 的 元 素 进行 控制 。 

属性 。 

。 Name: 设 定 提交 信息 时 的 信息 名 称 , 对 应 HTML 文档 Textarea 的 Name。 
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。 Value: 用 以 设 定 出 现在 窗口 中 对 应 HTML 文档 中 Value 的 信息 。 
。 Default value: 元 素 的 默认 值 。 

方法 。 

blur: 将 失去 输入 焦点 。 

select: 将 文字 加 亮 。 

事件 。 

。 onBlur: 当 失 去 输入 焦点 后 产生 该 事件 。 

。 onFocus: 当 输 入 获得 焦点 后 ,产生 该 文件 。 

。 Onchange: 当 文 字 值 改变 时 ,产生 该 事件 。 

。 Onselect: 当 文 字 加 亮 后 ,产生 该 文件 。 

3) Select( 选 择 元 素 ) 

功能 : 实施 对 滚动 选择 元 素 的 控制 。 

属性 。 

。 Name: 设 定 提交 信息 时 的 信息 名 称 , 对 应 文档 select 中 的 name。 
。 Length: 对 应 文档 select 中 的 length。 

。 Options: 组 成 多 个 选项 的 数组 。 

。 selectIndex: 该 下 标 指明 一 个 选项 。 

在 select 中 每 一 选项 都 含有 以 下 属性 。 

。 Text: 选项 对 应 的 文字 。 

。 selected: 指明 当前 选项 是 否 被 选中 。 

。 Index: 指明 当前 选项 的 位 置 。 

。 defaultselected: 默认 选项 。 

事件 。 

。 OnBlur: 当 select 选项 失去 焦点 时 ,产生 该 文件 。 

。 OnFocus: 当 select 获得 焦点 时 ,产生 该 文件 。 

。 Onchange: 选项 状态 改变 后 ,产生 该 事件 。 

4) Button( 按 钮 ) 

功能 : 实施 对 按钮 的 控制 。 

属性 。 

。 Name: 设 定 提交 信息 时 的 信息 名 称 , 对 应 文档 中 button 的 Name。 
。 Value: 用 以 设 定 出 现在 窗口 中 对 应 HTML 文档 中 Value 的 信息 。 


方法 。 

click: 类 似 于 一 个 按 下 的 按钮 。 
事件 。 

onclick: 当 单 击 按钮 时 ,产生 该 事件 。 
例如 : 


<Form name= "test"> 
< input type= "button" name= "testcall™" onclick= tmyest ()> 
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5) checkbox( 检 查 框 ) 

功能 : 实施 对 一 个 具有 复 选 框 中 元 素 的 控制 。 

属性 。 

。 Name: 设 定 提交 信息 时 的 信息 名 称 。 

， Value: 用 以 设 定 出 现在 窗口 中 对 应 HTML 文档 中 Value 的 信息 。 

。 Checked: 该 属性 指明 框 的 状态 true/false。 

。 defaultchecked: 默认 状态 。 

方法 。 

click: 使 得 框 的 某 一 个 项 被 选中 。 

事件 。 

onclick: 方 框 的 选项 被 选中 时 ,产生 该 事件 。 

6) radio( 单 选 按钮 ) 

功能 : 实施 对 一 个 具有 单 选 功能 的 无 线 按钮 控制 。 

属性 。 

name: 设 定 提交 信息 时 的 信息 名 称 ,对 应 HTML 文档 中 radio 的 name。 

value: 用 以 设 定 出 现在 窗口 中 对 应 HTML 文档 中 Value 的 信息 ,对 应 HTML 文 

档 中 radio 的 name。 

length: 单 选 按钮 中 的 按钮 数目 。 

defaultchecked: 默认 按钮 。 

checked: 指明 选中 还 是 没有 选中 。 

index: 选中 按钮 的 位 置 。 

方法 。 

chick: 选 定 一 个 按钮 。 

事件 。 

onclick: 单 击 按钮 时 ,产生 该 事件 。 

7) hidden( 隐 藏 ) 

功能 : 实施 对 一 个 具有 不 显示 文字 并 能 输入 字符 的 区 域 元 素 的 控制 。 

属性 。 

。 Name: 设 定 提交 信息 时 的 信息 名 称 , 对 应 HTML 文档 的 hidden 中 的 Name。 

。 Value: 用 以 设 定 出 现在 窗口 中 对 应 HTML 文档 中 Value 的 信息 ,对 应 HTML 
文档 中 hidden 的 value。 
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。 defaultvalue: 默认 值 。 
8) Password( 密 码 ) 
功能 : 实施 对 具有 密码 输入 的 元 素 的 控制 。 
属性 。 
。 Name: 设 定 提交 信息 时 的 信息 名 称 , 对 应 HTML 文档 中 password 的 name。 
。 Value: 用 以 设 定 出 现在 窗口 中 对 应 HTML 文档 中 Value 的 信息 ,对 应 HTML 
文档 中 password 的 Value。 
。 defaultvalue: 默认 值 。 
方法 。 
。 select: 加 亮 输入 密码 域 。 
。 blur: 丢失 password 输入 焦点 。 
。 focus: 获得 password 输入 焦点 。 
9) submit( 提 交 元 素 ) 
功能 : 实施 对 一 个 具有 提交 功能 按钮 的 控制 。 
属性 。 
Name: 设 定 提交 信息 时 的 信息 名 称 , 对 应 HTML 文档 中 的 submit。 
Value: 用 以 设 定 出 现在 窗口 中 对 应 HTML 文档 中 Value 的 信息 ,对 应 HTML 文档 
中 的 value。 
方法 。 
click: 相当 于 按 下 submit 按钮 。 
事件 。 
onclick: 当 按 下 该 按钮 时 ,产生 该 事件 。 


3. 范例 


下 面 演示 通过 单 击 一 个 按钮 (red) 来 改变 窗口 颜色 , 单 击 “ 调 用 动态 按钮 文档 "(如 
图 2-6) 调 用 一 个 动态 按钮 文档 ,该 动态 按钮 文档 如 图 2-7 所 示 。 
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和 

</script> 

< /HEAD> 

<body bgColor= "White" > 

<A href= "test8 2.htm"> 调 用 动态 按钮 文档 < /a> 
<form > 


< Input type= "button" Value= "red" onClick= "changecolor () "> 


</fom> 
< /BODY> 
< /HIML> 
| 页 -这 -四 昌 外遇 量 吉 
[| weris oso hes 
图 2-6 动态 按钮 文档 
<HIML> 
< HEAD> 
< /HEAD> 


<p align= "center">< /p> 
<div align= "center">< center> 
<table border= "0" cellspacing= "0" cellpadding= "0"> 
<tr> 
<td width= "100% ">< form name= "form?2" onSubmit= "null"> 
<p><input type= "submit" name= "banner" VALUE= "Submit" 
‘onClick= "alert ('You have to put an \'action= [url]\' on the form tag!!')"><br> 
< script language= "JavaScript"> 
Var id,pause= 0,position=07 
function banner() { 
// variables declaration 
var ivkrmsg= "这 里 输入 你 要 的 内 容 ";// increase msg 
k= (30/msg.length)+17 
for(i=0;i<=k;i++) msg+=" "+msg; 
// show it to the window 
document .form?.banner .value=msg. substring (position, position— 30); 


// set new position 
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图 2-7 程序 运行 结果 


本 章 介绍 了 使 用 JavaScript 脚本 实现 Web 页 面 信息 交互 的 方法 ,其 中 主要 介绍 了 窗 
体 中 基本 元 素 的 主要 功能 和 使 用 。 
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本 章 主 要 讲述 ASP. NET 的 基础 知识 ,包括 开发 环境 的 配置 ,.C# 语言 基础 、 
ASP. NET 的 一 些 常用 控件 及 ASP. NET 的 基本 对 象 。 通 过 本 章 学 习 将 会 对 ASP. NET 
有 一 定 的 了 解 , 为 以 后 开发 系统 竟 定 基础 。 


3.1 Visual Studio.NET 2005 


Visual Studio. NET 是 . NET 的 最 佳 开 发 工具 。Visual Studio. NET 是 一 套 完整 的 
开发 工具 ,用 于 生成 ASP. NET Web 应 用 程序 .XML Web Services、 桌 面 应 用 程序 和 移动 
应 用 程序 。Visual Basic. NET、Visual C++. NET .Visual C#.NET 和 Visual J#.NET 
全 部 使 用 相同 的 集成 开发 环境 (Integrated Development Environment,IDE) ,该 环境 允许 
它们 共享 工具 并 有 助 于 创建 混合 语言 解决 方案 。 另 外 ,这 些 语 言 利用 了 . NET Frame- 
work 的 功能 ,此 框架 提供 对 简化 ASP. NET Web 应 用 程序 和 XML Web Services 开发 关 
键 技术 的 访问 。 


3.1.1 导 人 导出 设置 


Visual Studio. NET 2005 包含 许多 对 开发 环境 新 的 增强 、 创 新 和 提高 。 图 3-1 为 启 
动 Visual Studio. NET 2005 的 常规 界面 。 在 Visual Studio. NET 2005 发 布 以 前 ,IDE 自 
定义 的 主要 不 足 之 处 是 ,无 法 以 可 移植 的 格式 保存 首选 项 。 使 用 Visual Studio. NET 
2005, 可 以 在 另 一 台 计 算 机 上 快速 地 还 原 个 人 设置 。Visual Studio. NET 2005 允许 以 如 
下 方式 使 用 自 定义 设置 : 制作 当前 设置 的 副本 以 供 另 一 台 计算 机 使 用 ;将 设置 分 发 给 其 
他 开发 人 员 ;允许 团队 对 IDE 的 某 些 元 素 使 用 相同 的 设置 ,而 在 IDE 的 其 他 区 域内 保留 
个 人 的 自 定 义 设置 。 
选择 “工具 ”>“ 选 项 ”命令 ,在 “选项 ”对 话 框 的 “环境 ” 结 点 中 ,选择 “导入 和 导出 设置 ” 
项 ,如 图 3-2 所 示 。 在 “将 我 的 设置 自动 保存 到 此 文件 ”文本 框 中 ,指定 的 文件 在 每 次 关闭 
Visual Studio 时 都 会 进行 更 新 。 它 可 以 是 本 地 文件 ,也 可 以 是 网 络 文 件 。 在 经 常 操作 两 
台 计 算 机 的 情况 下 ,将 该 文件 设置 在 两 台 计 算 机 都 可 以 访问 的 网 络 位 置 ,这 样 能 够 确保 在 
台 计 算 机 上 均 享用 相同 的 Visual Studio“ 外 观 ”。 另 外 ,每 次 更 新 其 中 一 人 台 计 算 机 设置 
时 , 它 都 会 自动 在 另 一 台 计 算 机 上 显示 。 
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新 闻 频 道 可 能 无 效 或 低 的 Iai 
能 不 可 用 。 志 要 更 改 者 闻 频 道 ， 请 在 “工具 ”菜单 上 
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男 
加 
间 
引导 
上 
日 
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3-1 Visual Studio. NET 2005 启动 后 的 初始 页 


|D: WBwckup\ 我 的 文档 \Wi sual Studio 2005\Settings\Curr] [浏览 8) 


思 便 用 国 队 设置 文件 Ey 

于 并 和 兰 执 [DVBwemap \ 我 的 文档 Wi sasl Studio 2005\Settines\Curr| 
了 

局 动 

区 域 设置 


Yeb 浏览 器 
帮助 


任务 列表 

外 接 程 序 / 宏 的 安全 性 
文档 

es 


到 eae 
外 | 
由 文本 编辑 | 
| 外 INL Ec 


3-2 导入 和 导出 设置 


在 “使 用 团队 设置 文件 ” 复 选 框 下 的 文本 框 中 ,可 指定 一 个 . vssettings 文件 夹 包含 在 
一 组 开发 人 员 中 的 共享 设置 。 一 个 开发 团队 的 所 有 成 员 都 必须 使 用 Visual Studio. NET 
代码 ,文件 应 该 具有 相同 的 缩 进 和 格式 化 选项 。 开 发 人 员 主 管 可 以 配置 Visual Studio 
.NET 2005 中 格式 化 选项 ,然后 使 用 导入 导出 设置 对 话 框 将 这 些 格式 化 设置 保存 到 网 络 
共享 . vssettings 文件 中 。 然 后 ,开发 团队 的 其 他 成 员 更 新 他 们 的 Visual Studio 配置 以 使 
用 该 团队 的 设置 文件 。 如 果 该 团队 以 后 决定 更 新 默认 值 , 则 开发 人 员 主 管 可 以 将 新 设置 
导出 到 相同 的 文件 位 置 ,该 团队 中 每 个 成 员 在 他 们 下 次 启动 Visual Studio 时 都 将 自动 接 
收 到 此 新 设置 。 

决定 更 新 默认 值 , 则 开发 人 员 主 管 可 以 将 新 设置 导出 到 相同 的 文件 位 置 , 该 团队 中 每 
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个 成 员 在 他 们 下 次 启动 Visual Studio 时 都 将 自动 接收 到 此 新 设置 。 

首次 启动 Visual Studio. NET 2005 时 所 选 的 设置 ,包括 已 安装 . vssettings 文件 中 的 
预定 义 、 自 定义 ,以 及 其 后 进行 的 任何 IDE 的 自 定义 ,在 每 次 退出 Visual Studio 时 ,活动 
设置 都 会 自动 保存 到 currentsettings. vssettings 文件 中 。 

当 用 户 希 望 改变 或 者 重 设置 工作 环境 时 ,可 以 选择 “工具 ”>“ 导 入 和 导出 设置 ”命令 。 
在 弹出 的 对 话 框 中 ,如 图 3-3 所 示 , 有 如 下 三 种 选择 : 导出 选 定 的 环境 设置 .导入 选 定 的 
环境 设置 和 重 置 所 有 设置 。 该 对 话 框 可 以 让 用 户 分 别 选择 将 那些 设置 导出 到 . vssettings 
文件 ,或 者 从 现 有 的 . vssettings 文件 导入 那些 设置 ,如 图 3-4 所 示 。 


导入 和 导出 设置 向 导 


功 司 欢迎 使 用 “导入 和 导出 设置 向 导 ” 


区] 


可 以 使 用 此 向 导 来 导入 或 导出 特定 的 设置 类 别 ， 或 梅 环境 重 置 为 某 一 默认 设置 集合 . 


您 希望 做 什么 ? 


晤 | 导出 连 定 的 环境 设置 
件 中 ,以便 以 后 可 以 随时 导 人 齐 任 何 计算 机 中 。 
〇 导入 选 定 的 环境 设置 (I) 
从 文件 中 导入 设置 以 格 其 应 用 到 环境 中 。 
人 〇 重 置 所 有 设置 @) 
将 所 有 环境 设置 重 置 为 某 一 默认 设置 集合 。 


图 3-3 “导入 和 导出 设置 向 导 ” 对 话 框 


ed 站 导 


[3 ” 园 择 要 导出 的 设置 


上 某 些 类 别 中 包含 的 设置 可 能 会 滴漏 有 关 悠 或 您 的 计算 机 的 信息 。 


肪 | 说 明 : 
LEE 2 


图 3-4 选择 导入 导出 的 设置 


通过 Visual Studio. NET 2005 的 “导入 和 导出 设置 ”, 可 以 灵活 地 控制 IDE 开发 的 设 
置 ,这 对 个 人 开发 和 团队 开发 都 非常 便利 、 快 捷 。 
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3.1.2 常用 窗口 


1.“ 工 具 箱 "窗口 

与 Visual Studio. NET 2003 相 比 ,Visual Studio. NET 2005 工具 箱 的 一 个 重要 的 变 
化 是 包含 更 加 丰富 的 工具 控件 ,图 3-5 所 示 为 “工具 箱 ” 
窗口 。 

根据 所 创建 应 用 程序 的 类 型 ,工具 箱 中 将 包含 不 同 的 
控件 群 。 以 编写 ASP. NET 应 用 程序 为 例 , 默 认 情 况 下 ， 
打开 一 个 .aspx 文件 后 ,工具 箱 将 出 现 8 个 控件 群 。 每 个 
控件 群 中 包含 多 个 功能 相似 的 控件 ,下 面 是 对 8 个 控件 群 。 图 3.5 工具 箱 * 窗 吕 
的 简要 说 明 。 

(1) 标准 : 包含 最 常用 的 控件 。 所 有 控件 有 一 个 共同 特征 ,代码 中 都 包含 二 asp: 二 。 
例如 ,常见 的 Textbox、FileUpload 和 Wizard 等 。 

(2) 数据 : 包含 多 个 数据 源 和 数据 绑 定 控件 ,这 些 控件 能 够 连接 和 显示 不 同 数据 源 
数据 ,如 SQL Server、Access 和 XML 等 。 

(3) 验证 : 包含 所 有 与 数据 验证 有 关 的 控件 ,如 RequiredFieldValidator、RangeVali- 
dator 等 。 利 用 这 些 控 件 可 快速 实现 数据 验证 。 

(4) 导航 : 用 于 实现 站 点 导航 功能 ,如 Menu、SiteMapPath 和 TreeView 等 。 

(5) 登录 : 包含 与 用 户 登录 有 关 的 服务 器 控件 ,如 Login、LoginView、LoginName 和 
CreateUserWizard 等 。 

(6) WebParts: 包含 所 有 Web 部 件 控件 ,如 WebPartZone、WebPartManager 等 。 

(7) HTML: 包含 常用 HTML 控件 ,如 Button、Table 等 。 

(8) 常规 : 不 包含 任何 控件 。 可 以 将 自 定义 的 常用 控件 添加 到 该 控件 群 中 。 

2.“ 属 性 ”窗口 

“属性 "窗口 主要 用 于 显示 选 定 对 象 的 具体 属性 信息 ,利用 “属性 "窗口 可 方便 修改 对 
象 属性 。 图 3-6 所 示 的 是 按钮 控件 的 相关 属性 。 
> “属性 ”窗口 上 部 有 一 个 下 拉 列 表 框 , 框 中 显示 
间 了 当前 被 选中 对 象 的 名 称 和 完整 类 名 。 可 以 利用 该 
下 拉 列 表 框 对 页 面 中 的 多 个 对 象 进行 选择 ,进而 查 
看 属性 信息 。 在 下 拉 列 表 框 的 下 部 是 一 个 工具 条 ， 
工具 条 中 包含 按 分 类 顺序 查看 属性 、 按 字母 顺序 查 
看 其 属性 事件 和 查看 属性 页 的 功能 按钮 。“ 属 性 ” 
窗口 中 部 是 信息 列表 。 所 有 与 选 定 对 象 相关 的 属性 
或 者 事件 信息 等 都 显示 在 这 个 区 域 。“ 属 性 ”窗口 的 
下 部 是 说 明 区 域 。 由 于 属性 众多 ,用 户 不 可 能 对 每 
个 属性 都 了 如 指 掌 。 因 此 ,说 明 区 域 的 设置 则 起 到 
图 3-6 “属性 "窗口 了 很 大 的 辅助 作用 。 在 属性 信息 列表 中 , 单 击 任何 
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属性 时 ,信息 说 明 区 域 将 立刻 显示 属性 的 简单 说 明 。 

3. 解决 方案 资源 管理 器 

“解决 方案 资源 管理 器 ”是 Visual Studio 2005 中 最 为 重要 的 功能 窗口 , 它 可 以 完成 对 
解决 方案 中 代码 文件 .图 片 等 资源 的 管理 任务 。 例 如 ,对 资源 的 复制 .粘贴 和 删除 等 。 另 
外 ,还 能 够 实现 对 解决 方案 的 配置 和 操作 等 。 例 如 ,编译 项 目 .查看 属性 、 添 加 文件 和 项 设 
置 启动 项 目 等 。 图 3-7 所 示 为 “解决 方案 资源 管理 器 "窗口 的 截图 。 

“解决 方案 资源 管理 器 "窗口 中 包含 一 个 存储 在 *E:\ 项 目 \EnglishView\" 中 的 Web 
站 点 项 目 。 该 项 目 中 文件 以 树 形 结构 显示 在 窗口 中 ,同时 ,在 窗口 上 部 还 包含 一 个 工具 
条 。 图 3-8 所 示 为 这 些 按钮 的 说 明 。 

在 “解决 方案 资源 管理 器 "窗口 的 上 部 设置 了 一 个 工具 条 。 该 工具 条 中 包含 7 个 常用 
的 功能 按钮 ,这 些 按钮 包含 属性 、 刷 新 、 嵌 套 相关 文件 .查看 代码 ,查看 设计 器 .复制 网 站 和 
ASP. NET 配置 。 用 户 可 根据 需要 选择 使 用 这 些 按钮 。 另 外 ,工具 条 中 的 按钮 也 会 随 着 
不 同 的 选择 对 象 呈 现 动态 变化 。 例 如 ,图 3-7 所 示 的 是 . aspx 文件 后 的 工具 条 状态 。 如 果 
选中 项 目 文件 夹 , 则 工具 条 还 会 显示 “查看 类 关系 图 ”按钮 ,并 隐藏 “查看 代码 ”和 “查看 设 
计 器 ?按钮 。 

4. 服务 器 资源 管理 器 

默认 情况 下 ,“ 服 务 器 资源 管理 器 ”窗口 与 “解决 方案 资源 管理 器 "窗口 处 于 同一 位 置 ， 
二 者 采用 类 似 选 项 卡 的 形式 重 倒 放置 在 一 起 。 通 过 单 击 选项 卡 ,可 以 在 两 个 窗口 之 间 进 
行 切换 。 图 3-9 为 “服务 器 资源 管理 器 "窗口 的 截图 。 


谋 夺 相关 文件 查看 设计 只 ASPNET 配 轩 
ElLishyiew” (1 个 项 目 ) 


a 
解决 方案 
日 多 总 ee en 
9 bfyy a ~ 
属性 刷新 查看 代 色 复制 项 目 
图 3-8 解决 方案 资源 管理 器 中 的 工具 条 


图 困 图 困 困 因 图 图 图 图 因 田 田 图 田 


图 图 因 轩 因 力 
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图 3-7 “解决 方案 资源 管理 器 ”窗口 图 3-9 “服务 器 资源 管理 器 ”窗口 
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“服务 器 资源 管理 器 ”窗口 有 一 个 资源 树 , 树 中 包含 数据 连接 ,服务 和 管理 类 等 内 容 。 利 
用 这 个 服务 器 资源 树 ,能 够 方便 地 完成 如 连接 数据 库 .连接 服务 器 和 查看 服务 信息 等 任务 。 

5. 类 视图 

在 类 视图 中 ,如 图 3-10 所 示 ,用户 可 以 清晰 地 得 到 当前 项 目 类 的 组 织 情况 ,以 及 每 个 
类 的 基 类 和 接口 ` 成 员 变量 .函数 等 。 双 击 相应 的 变 
量 、 函 数 , 则 会 直接 定位 到 其 相应 代码 处 。 在 类 视图 
对 应 工具 栏 中 ,用 户 可 以 改变 类 视图 的 排序 方式 ,也 | 地 rTeTR 
可 以 建立 新 的 文件 夹 。 同 样 ,用 户 需 要 注意 这 里 丰 | S 交 台 5 蝎 
富 的 右键 菜单 。 而 且 ,右键 指向 的 位 置 不 同 (指向 子 | 加 训 于 
结 点 还 是 根 结 点 ) ,其 对 应 的 右键 菜单 也 会 不 同 ,就 | YY 


国人 zhaopinDB 


可 以 带 来 不 同 的 快捷 操作 。 ey 
同时 ,类 视图 还 是 一 种 可 视 化 设计 工具 ,用 于 检 ea 


查 和 操作 类 和 其 他 类 型 的 结构 。 该 工具 与 设计 器 所 

显示 的 类 型 底层 的 源 代 码 完 全 集成 ,例如 ,如 果 更 改 了 一 个 属性 名 ,该 代码 文件 会 自动 进 
行 更 新 以 反映 此 更 改 。 反 过 来 ,在 源 代码 中 所 做 的 更 改 也 会 立即 影响 到 设计 器 中 与 相关 
联 对 象 的 外 观 。 


3.1.3 创建 Welcome Web 应 用 程序 


1. 启动 Visual Studio 2005 建立 Web 网 站 

当 第 一 次 启动 Visual Studio 2005 时 ,系统 会 自动 进行 相关 的 配置 。 选 择 “ 开 始 ” 一 
“所 有 程序 ”>Microsoft Visual Studio 2005 命令 ,启动 Visual Studio 2005。 

Visual Studio 2005 可 以 建立 HTTP 或 文件 系统 网 站 。 文 件 系 统 网 站 是 保存 在 硬盘 
文件 夹 的 Web 网 站 ,需要 发 布 至 Web 服务 器 ,或 使 用 内 建 服务 器 测试 ASP. NET 程序 的 
执行 ,其 步骤 如 下 。 

(1) 启动 Visual Studio 2005 ,然后 选择 "文件 ”新建 ”网 站 ”命令 ,打开 * 新 建 网 
站 ”对 话 框 ,如 图 3-11 所 示 。 


模板 并 ) 
Wisual Studie 已 安装 的 模板 
国 MSP IET 网 站 轧 Asp ET web 服务 葬 个 人 网 站 初学 者 工具 包 
网 主 网 站 请 ASP. HET Crystal Reports 下 


周 搜 索 联机 模板 


空 ASP. 了 ET 网 站 
位 置 必 ): | 文件 系统 
语言 @): [Wim ce_ 


图 3-11 “新 建 网 站 ”对 话 框 
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(2) 在 “模板 ?列表 框 中 选择 “ASP. NET 网 站 ”, 在 “位 置 ? 下 拉 列 表 中 选择 “文件 系 
统 ” 选 项 ,就 可 以 选择 文件 夹 来 建立 文件 系统 网 站 。 本 例 选择 “文件 系统 ”选项 ,在 其 后 的 
文本 框 中 输入 下 : \Welcome, 单 击 * 确 定 ”按钮 创建 网 站 。 

(3) 网 站 默认 建立 Default. aspx 网 站 首页 文件 和 Default. aspx. cs, 并 且 建 立 App_ 
Data 子 目录 ,如 图 3-12 所 示 。 
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3-12 ”新建 的 网 站 


2. 添加 内 容 

通过 Visual Studio 2005 提供 的 工具 箱 可 以 向 页 面 添加 各 种 控件 ,本 例 简 单 地 向 页 面 
中 添加 一 个 Label 控件 来 显示 Welcome 消息 .具体 步骤 如 下 所 示 。 

(1) 单 击 图 3-13 所 示 窗 口 底部 的 “设计 ?按钮 ,进入 "设计 ”窗口 。 


已 设计 | 回 源 


| 
E33 


图 3-13 “设计 ”窗口 
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(2) 将 Lable 控件 拖 入 “设计 ”窗口 .定义 该 控件 的 ID、Text、Font 和 ForeColor 属性 ， 
如 图 3-14 所 示 。 


文件 四 ”编辑 视图) 网 站 多) 生成 四 调式) 格式 @) 布局 ) 工具 测 式 &) 窗口 人 
社区 EC) 帮助 只 
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图 3-14 设置 控件 
(3) 单 击 工具 栏 上 的 “保存 ”按钮 ,保存 文件 。 
3. 调试 ASP. NET 程序 
选择 “调试 ”启动 调试 ”命令 , 即 可 在 浏览 器 中 查看 该 程序 ,如 图 3-15 所 示 。 


怨 无 标题 页 - Microsoft Internet Explorer 
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3-15 ” Welcome 页 面 


这 样 ,ASP.NET 网 站 的 整个 实现 过 程 就 演示 完毕 了 。 
3.2 C 井 基础 


3.2.1 C+# 概 述 


1. C# 和. NET 框架 


1) 什么 是 . NET 框架 
. NET 定义 了 一 种 支持 高 度 分 散 、 基 于 组 件 的 应 用 程序 的 开发 和 执行 环境 。 它 允许 
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不 同 计算 机 语言 一 起 工作 ,并 给 Windows 平台 提供 安全 性 、 程 序 可 移植 性 和 通用 程序 
模型 。 

2) C# 和 . NET 框架 的 关系 

C# 和 运行 环境 . NET 框架 具有 特殊 关系 。 

(1) Microsoft 最 初 设计 C# 是 为 了 给 . NET 框架 创建 代码 。 

(2) C# 使 用 的 库 就 是 . NET 框架 所 定义 的 库 。 

由 于 . NET 框架 与 C# 相关, 为 了 让 多 种 不 同 的 计算 机 语言 在 一 起 工作 ,. NET 定义 
了 两 个 重要 的 实体 。 

(1) 通用 语言 运行 时 (Common Language Runtime, CLR), 这 是 管理 程序 执行 的 系 
统 。CLR 是 . NET 框架 中 允许 程序 移植 .支持 混合 语言 设计 和 提供 安全 性 的 一 部 分 。 

(2) .NET 类 库 ,该 库 让 程序 有 权 访 问 运行 环境 。 只 要 程序 满足 . NET 类 库 定 义 的 
特征 , 它 就 能 在 任何 支持 . NET 的 地 方 运行 。 

2. C# 程 序 实例 

现在 来 看 一 个 实际 的 C# 程 序 ,编译 并 运行 程序 3-1。 

程序 3-1 实现 简单 的 输出 


using System; 
class Example 
{ 
Public static void Main () 
1 
Console.WriteLine ("A simple C# program."); 
} 
} 


使 用 Visual Studio 集成 开发 环境 编辑 编译 和 运行 C# 程序 。 下 面 是 关于 C# 程 序 
的 说 明 。 

(1) C# 程 序 的 名 称 是 任意 的 ,只 要 遵循 其 扩展 名 为 . CS 即 可 。 例 如 本 实例 程序 名 为 
Example. cs。 

(2) C# 中 大 写 和 小 写字 母 是 有 区 别 的 。 例 如 不 小 心 将 Main 输入 成 main, 或 者 将 
WriteLine 输入 成 writeline, 那 么 上 面 的 程序 将 是 错误 的 。 

(3) C# 使 用 如 下 三 种 注释 方法 。 

多 行 注释 : /x*…x/ 

单行 注释 : // 

XML 注释 : /// 

(4) 语句 using System; 表示 程序 使 用 System 名 字 空 间 。 在 C# 中 名 字 空 间 
(namespace) 定 义 声明 范围 。 名 字 空 间 提 供 使 一 组 名 称 与 其 他 名 称 分 开 的 方式 。 基 本 
上 ,一 个 名 字 空 间 中 声明 的 名 称 将 不 会 与 另 一 个 名 字 空 间 中 声明 的 名 称 相 冲突 。 如 果 需 
要 ,可 以 用 它 所 属 名 字 空 间 完 全 限定 名 称 。 
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(5) class Example 语句 ,使 用 关键 字 class 说 明正 在 定义 一 个 新 类 。 

(6) 关于 Public static void Main 的 说 明 如 下 。 

@D Public 关键 字 是 一 个 访问 说 明 符 。 访 问 说 明 符 确定 程序 其 他 部 分 如 何 访问 类 的 
成 员 。Public 表示 类 外 面 代码 能 访问 该 成 员 。 因 为 程序 开始 执行 Main( ) 将 由 它 所 在 类 
的 外 面 代码 (操作 系统 ) 来 调用 .所 以 声明 为 Public。 

@ static 表示 人 允许 在 创建 Main( ) 所 在 类 的 对 象 之 前 调用 Main( )。 由 于 Main( ) 是 
在 程序 启动 时 调用 的 ,所 以 这 是 必需 的 。 

@ void 表明 Main( ) 不 返回 值 。 

(7) 代码 块 : { 两 个 或 多 个 语句 } 整 体 表 示 逻 辑 块 。 

(8) 处 理 语言 错误 。 

由 于 语言 写 什么 ,C# 编 译 器 都 试图 了 解 源 代码 ,因此 所 报告 的 信息 往往 不 能 反映 问 
题 的 所 在 原因 。 当 程序 包含 错误 语法 时 ,不 必 完 全 接受 编译 器 表面 的 信息 ;它们 可 能 是 误 
导 。 为 了 找到 问题 的 所 在 ,需要 “推测 ”错误 信息 。 另 外 .需要 查看 错误 信息 所 在 代码 前 面 
的 几 行 代码 。 有 时 ,在 实际 问题 所 在 位 置 之 后 几 行 才 有 错误 报告 。 

3. 关键 字 和 标识 符 

1) 关键 字 

C# 语 言 中 ,关键 字 有 77 个 ,如 表 3-1 所 示 。 这 些 关 键 字 不 能 作为 变量 、 类 或 方法 的 
名 称 来 使 用 。 


表 3-1 C# 关 键 字 
abstract as base bool break byte case catch 
char checked class const continue decimal default delegate 
do double else enum event explicit extern false 
finally fixed float for foreach goto 证 implicit 
in int interface internal is lock long namespace 
new null object operator out override params private 
protected | public readonly ref return sbyte sealed short 
sizeof stackalloc | static string struct switch this throw 
true try typeof unit ulong unchecked | unsafe ushort 
using virtual volatile void while 


2) 标识 符 

在 C# 中 ,标识 符 是 分 配给 方法 、 变 量 或 任何 其 他 用 户 自 定义 对 象 的 名 称 。 

(1) 标识 符 由 字母 .数字 和 下 划 线 组 成 .以 字母 .下划线 打头 。 

(2) 标识 符 中 大 写 和 小 写 是 有 区 别 的 。 

(3) C# 人 允许 在 关键 字 前 面 加 上 一 个 @ 作 为 有 效 标识 符 , 但 并 不 建议 使 用 。 

(4) 命名 时 尽量 遵循 以 下 规则 。 每 个 名 字 由 几 个 单词 连接 而 成 ;对 于 类 名 和 方法 ,每 
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个 单词 开头 大 写 ; 对 于 变量 名 ,第 一 个 字母 不 用 大 写 ;常量 全 部 用 大 写 标识 符 定义 。 


3.2.2 基本 数据 类 型 


C# 有 了 两 种 基本 的 类 型 : 一 种 是 值 (value types) .一 种 是 引用 (reference types)。 值 
包括 简单 类 型 (char int 和 float) 、 枚 举 (enum) 和 结构 (struct)。 引 用 包括 类 (class) ,界面 
(Interface) ,代表 (delegate) 和 数组 (array)。 

值 与 引用 的 不 同 之 处 在 于 : 值 直接 存储 它 的 数据 内 容 , 而 引用 存储 对 象 的 引用 。 值 
和 引用 的 区 别 可 以 引出 一 个 重要 特性 。 值 的 变量 和 变量 存储 的 数据 是 一 一 对 应 的 ,是 唯 
一 的 。 而 引用 则 不 然 , 引 用 中 不 同 的 变量 可 以 引用 同一 个 对 象 的 实例 。 当 其 中 一 个 变量 
改变 实例 的 值 时 ,其 他 引用 这 个 实例 的 变量 也 会 受到 影响 (当然 ,变量 本 身 并 没有 改变 , 即 
地 址 没 变 ) 。 如 程序 3-2 所 示 。 

程序 3-2 值 和 引用 的 区 别 


输出 结果 如 下 : 


变量 vall 和 变量 val2 互 不 影响 ,它们 各 自 有 自己 的 存储 空间 。 而 ref2 复制 了 refl， 
所 以 它们 引用 了 同一 个 对 象 的 实例 。 当 改变 它们 其 中 一 个 的 时 候 , 就 会 影响 到 另 一 个 
的 值 。 
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1. 值 类 型 
表 3-2 给 出 了 C# 可 以 使 用 的 值 类 型 。 
表 3-2 C# 中 的 值 类 型 


类 型 字 节 数 描 述 类 型 字 节 数 描 述 
byte 1 无 符号 字 节 ulong 8 无 符号 大 整数 
sbyte 1 有 符号 的 字 节 float 4 浮 点 数 

short bE 有 符号 的 短 字 节 double 8 双 精 度数 
ushort 2 无 符号 的 短 字 节 decimal 8 固定 精度 数 

int 4 有 符号 的 整 型 数 string Unicode 字符 串 
uint 4 无 符号 的 整 型 数 char Unicode 字符 
long 8 有 符号 大 整数 bool Boolean 值 


VB 和 C 程序 员 都 可 能 会 对 int 和 long 数据 类 型 所 代表 的 新 范围 感到 惊讶 。 和 其 他 
的 编程 语言 相 比 ,在 C# 中 ,int 不 再 取决 于 一 个 机 器 中 字 (word) 的 大 小 ,而 long 被 设 成 
64 位 。 小 数 型 是 一 种 高 精度 .128 位 数据 类 型 , 它 用 于 金融 和 货币 的 计算 。 它 所 表示 的 范 
围 为 IE 一 28 一 7.9E 十 28, 具 有 28 一 29 位 有 效 数字 。 要 注意 ,精度 是 以 位 数 (digits) 而 不 
是 以 小 数位 (decimal places) 表 示 的 。 运 算 准确 到 28 个 小 数位 的 最 大 值 。 它 的 取信 范围 
比 double 的 还 窄 ,但 它 更 精确 。 因 此 ,没有 decimal 和 double 之 间 的 隐 式 转换 , 往 一 个 方 
向 转换 可 能 会 溢出 , 往 另外 一 个 方向 转换 可 能 会 丢失 精度 。 当 定义 一 个 变量 并 赋值 给 它 
时 ,使 用 m 后缀 以 表明 它 是 一 个 小 数 型 ,例如 : 

decimal decMyValue=1.0m; 

如 果 省 略 了 mo, 在 变量 被 赋值 之 前 , 它 将 被 编译 器 认 作 double 型 。 

2. 引用 类 型 

和 值 类 型 相 比 ,引用 类 型 不 存储 它们 所 代表 的 实际 数据 ,但 它们 存储 实际 数据 的 引用 
在 C# 中 提供 以 下 引用 类 型 可 以 使 用 : 对 象 类 型 类 类 型 接口、 代表 元 、 字 符 串 类 型 和 
数组 。 

1) 对 象 类 型 

对 象 类 型 是 所 有 类 型 之 母 . 它 是 其 他 类 型 最 根本 的 基 类 。 因 为 它 是 所 有 对 象 的 基 类 ， 
所 以 可 把 任何 类 型 的 值 赋 给 它 。 

例如 ,一 个 整 型 : 

object theObj= 123; 

2) 类 类 型 

一 个 类 类 型 可 以 包含 数据 成 员 、 函 数 成 员 和 肉 套 类 型 。 数 据 成 员 是 常量 .字段 和 事 
件 。 函 数 成 员 包 括 方法 、 属 性 、 索 引 、 操 作 符 、 构 造 函 数 和 析 构 函数 。 类 和 结构 的 功能 是 非 
常 相似 的 ,但 正如 前 面 所 述 ,结构 是 值 类 型 ,而 类 是 引用 类 型 。 和 C ++ 相 比 , 仅 允 许 单 继 
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承 (不 能 拥有 派生 一 个 新 对 象 的 多 重 基 类 )。 但 是 ,C# 中 的 一 个 类 可 以 派生 自 多 重 接口 。 

3) 接口 

一 个 接口 声明 一 个 只 有 抽象 成 员 的 引用 类 型 。 同 C++ 中 相似 的 概念 为 : 一 个 结构 的 
成 员 , 目 方法 等 于 0。C# 中 一 个 接口 实际 所 做 的 ,仅仅 存在 着 方法 标志 ,根本 就 没有 执行 
代码 。 这 就 暗示 了 不 能 实例 化 一 个 接口 ,只 能 实例 化 一 个 派生 自 该 接口 的 对 象 。 可 以 在 
一 个 接口 中 定义 方法 .属性 和 索引 。 当 定义 一 个 类 时 ,可 以 派生 自 多 重 接口 ,但 只 能 从 仅 
有 的 一 个 类 派生 。 

4) 代表 元 

一 个 代表 元 封装 了 一 个 具有 一 些 标志 的 方法 。 代 表 元 是 类 型 安全 和 函数 指针 的 安全 
版 本 (回调 功能 ) ,可 以 同时 在 一 个 代表 元 实例 中 封装 静态 和 实例 方法 。 

5) 字符 串 类 型 

C# 有 一 个 用 于 操作 字符 串 的 基本 字符 串 类 型 ,字符 串 类 直接 派生 自 对 象 , 且 是 被 封 
装 的 ,这 意味 着 不 能 再 从 它 派生 类 。 字 符 串 是 预定 义 类 System String 的 一 个 别名 。 

它 的 用 法 十 分 简单 ,例如 : 


string myString= "some text"; 

合并 字符 串 同 样 简单 ,例如 : 

string myString= "some text"+ "and a bit more"; 

如 果 想 访问 单个 字符 , 则 要 访问 下 标 , 即 : 

char chFirst=myString[0]; 

当 比 较 两 个 字符 串 是 否 相 等 时 ,简单 地 使 用 “三 = 二” 比较 操作 符 。 

if (myString== yourSstring) 

字符 串 是 一 个 应 用 类 型 ,比较 时 是 比较 值 ,而 不 是 比较 引用 (内 存 地 址 ) 。 

6) 数组 

一 个 数组 包含 有 通过 计算 下 标 访 问 的 变量 。 所 有 包含 于 数组 中 且 被 当 作 元 素 的 变量 
必须 是 同一 类 型 。 这 种 类 型 自然 被 称 为 “数组 类 型 "*。 数 组 可 以 存储 整数 对 象 、 字 符 串 对 
象 或 者 用 户 提出 的 任何 对 象 。 

用 一 个 数组 初始 化 器 (array initializer) 初 始 化 的 数组 

String [] arrLanguages={"C", "Ct+", "C# "}; 

该 语句 简写 效果 如 下 : 

arrLanguages[0]="C"; arrLanguages[1]="C++"; arrLanguages[2]="C# "; 

如 果 不 想 事先 初始 化 一 个 数组 ,但 知道 了 它 的 大 小 ,可 以 以 下 面 这 种 方式 声明 : 

Int[, JmyArr=new int [5,3]; 


如 果 数 组 的 大 小 必须 动态 计算 ,用 于 数组 创建 的 语句 可 以 这 样 写 : 
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int nVar=5; 


int arrToo=new int [nVar]; 


3. 加 框 和 消 框 

加 框 和 消 框 是 类 型 系统 的 核心 概念 。 通 过 人 允许 一 个 值 类 型 转换 成 类 型 对 象 或 从 
类 型 对 象 转换 成 值 类 型 ,这 种 机 制 形成 了 值 类 型 和 引用 类 型 之 间 的 捆绑 连接 。 

1) 加 框 转化 

给 一 个 值 加 框 , 指 隐 式 地 把 任何 值 类 型 转换 成 类 型 对 象 。 当 一 个 值 类 型 被 加 框 时 ,一 
个 对 象 实例 就 被 分 配 , 且 值 类 型 的 值 被 复制 给 新 的 对 象 。 

看 以 下 例子 : 

int nFunny= 20007 

object oFunny=nFunny; 

第 二 行 的 赋值 暗示 调用 一 个 加 框 操作 。nFunny 整 型 变量 被 复制 给 oFunny 对 象 。 
现在 整 型 变量 和 对 象 变量 都 同时 存在 于 栈 中 ,但 对 象 的 值 留 在 堆 中 。 

2) 消 框 转换 

和 加 框 相 比 , 消 框 是 显示 操作 ,必须 告诉 编译 器 要 从 对 象 中 抽取 哪 一 种 数据 类 型 。 当 
执行 消 框 操作 时 ,C# 检 测 所 请 求 的 值 类 型 实际 上 存储 在 对 象 事例 中 。 经 过 成 功 的 校 验 ， 
该 值 被 消 框 。 

继续 刚才 的 例子 ,进行 消 框 : 

int nFunny= 2000” 

object oFunny=nfunny; 

int nNotSoFunny= (int)oFunny; 


3.2.3 运算 符 


C# 提 供 大 量 的 运算 符 , 使 程序 设计 员 对 表达 式 的 结构 和 计算 进行 具体 控制 。C# 有 
5 种 基本 运算 符 : 算术 运算 符 、 关 系 运算 符 、 逻 辑 运算 符 、 赋 值 运算 符 和 位 运算 符 。 

1. 5 种 基本 运算 符 

1) 算术 运算 符 

C# 定 义 了 十 (加 )、 一 ( 减 )、x ( 乘 )、/( 除 )、%( 求 余 ) ,十 十 (递增 ) 和 一 一 ( 递 碱 )7 种 

关于 算术 运算 符 的 几 点 说 明 如 下 。 

(1) 十 ,一 、* 、/ 可 以 应 用 于 任何 内 部 数字 数据 类 型 。 

(2) % 可 以 应 用 于 整 型 数据 类 型 ,也 可 以 应 用 于 浮 点 数据 类 型 。 

(3) 关于 十 十 ,一 一 位 置 所 引起 的 区 别 : 当 递 增 运算 符 (或 递减 运算 符 ) 在 操作 数 之 
前 时 ,C# 在 获得 操作 数 的 值 用 于 表达 式 其 余部 分 的 运算 之 前 ,先进 行 递增 (或 递减 ) 运 
算 。 如 果 运 算 符 在 操作 数 的 后 面 .那么 C# 先 取得 该 操作 数 用 于 其 他 计算 ,然后 再 递增 
(或 递减 ) 它 。 


or 
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2) 关系 运算 符 

C# 定 义 了 = 一 ( 等 于 ).! 一 (不 等 于 )、>( 大 于 )、> 王 (大 于 等 于 )`<( 小 于 ) 和 到 = 
(小 于 等 于 )6 种 关系 运算 符 。 

(1) = 一 和 ! 一 可 以 比较 任意 对 象 是 否 相等 或 不 相等 。 

(2) >、> 一 过 和 去 一 只 能 用 于 那些 支持 次 序 关 系 的 类 型 ,因此 支持 任意 数字 类 
型 ,但 不 支持 bool 类 型 值 。 

(3) 经 关系 运算 后 的 运算 结果 为 bool 类 型 的 值 。 

3) 逻辑 运算 符 

C# 定 义 了 如 ( 与 )、|( 或 )、!1( 非 )、“^( 异 或 )、&& (短路 与 ) 和 | | (短路 或 )6 种 逻辑 运 
算 符 。 

(1) 对 于 逻辑 运算 符 ,其 操作 数 是 bool 类 型 ,并 且 逻 辑 运算 结果 也 为 bool 类 型 。 

(2) && 的 第 一 个 操作 数 为 0, 不 计算 第 二 个 操作 数 ,结果 为 假 。| | 的 第 一 个 操作 数 
为 1 ,不 计算 第 二 个 操作 数 ,结果 为 真 。 

(3) & 和 | 不 管 什么 情况 下 都 要 计算 两 个 操作 数 ,它们 是 按 位 运算 ,都 是 把 参加 运算 
的 数 以 二 进 制 形式 进行 运算 。 

4) 赋值 运算 符 

(1)“ 二 ”运算 符 。 

简单 赋值 : varl] 二 expression; 

赋值 链 : varl 一 var2 一 var3 一 expressiony 

(2) 复合 赋值 。 

对 于 所 有 二 元 运算 符 ,都 有 复合 赋值 运算 符 。 通 常 简写 形式 为 : 

Var op=expression; 


合 运算 符 比 普通 运算 符 更 简单 ,由 于 操作 数 只 计算 一 次 .因此 能 产生 更 高 效 的 可 执 

行 代码 。 

5) 位 运算 符 

CH# 定 义 了 尼 ( 按 位 与 )、|( 按 位 或 )、( 按 位 异 或 )、 一 ( 按 位 非 ) 志 二 ( 左 移 ) 和 二 二 
( 右 移 )6 种 位 运算 符 。 

(1) &、|、“^ 和 一 运算 符 说 明 如 下 。 

&&0: 用 于 清 0 操作 。 

11: 用 于 置 1 操作 。 

^: 0*varb=varb; ,1^varb 一 一 varb; 。 

一 : 各 位 求 反 ,用 于 求 补 码 和 反 码 运 算 。 

(2) 移 位 运算 符 二 二 二 二 。 

左 移 : 右边 补 0。 

右 移 : 无 符号 直接 在 左边 补 0; 有 符号 正 数 左 边 补 0, 有 符号 负数 左边 补 1。 

(3) 对 于 左 移 和 右 移 ,被 移 走 的 位 被 丢弃 .因此 移 位 运算 不 能 循环 ,没有 办 法 获得 被 
移出 的 位 。 
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(4) 移 位 运算 符 可 以 作为 整数 乘 2 或 除 2 的 快速 计算 方法 。 志 二 (加 倍 ) 和 二 二 ( 减 
半 ) 只 能 在 不 会 将 两 端 位 移出 时 使 用 。 

2. 运算 符 的 优先 级 

C# 运 算 符 的 优先 级 从 高 到 低 如 下 。 

(1) ()、 [了 ]、 十 十 (后 置 ) 一 (后 置 ) .checked、new sizeof、typeof、unchecked 

(2) !、 一 (cast)、 十 (一 元 ) .一 (一 元 )、 十 十 (前 置 ) ,一 一 (前 置 ) 

C37 SA 

(4) 十 ;二 

(6 之 

(6) >,>=.<,<=.,is 

(7) 一 一 、! 一 

(8) & 

i 

(10) | 

(11) && 

12 川 

(La 

(14) = ,op= 

3.2.4 程序 控制 语句 

编写 程序 时 最 重要 的 就 是 要 了 解 应 用 程序 的 控制 结构 ,控制 结构 是 通过 控制 语句 来 
实现 的 ,控制 语句 包括 条 件 语句 、 循 环 语句 和 跳 转 语句 。 

1. 条 件 语句 

C# 支 持 三 种 基本 的 条 件 语句 : if 语句、? 条 件 和 switch 语句 。 

1) 证 语句 

让 有 如 下 三 种 语句 。 

(13 


if( 条 件 ) 


82 网 站 建设 实用 教程 


(3) 


else if( 条 件 2) 
{ 

语句 2 
} 


else 
{ 

语句 N; 
} 


2) ? 条 件 


条 件 ? 语 句 1: 语句 2 
等 价 于 
if( 条 件 ) 
{ 
语句 ， 
else 
和 
语句 1; 
} 


3) switch 语句 


switch (条 件 ) 

{ 

case 常量 表达 式 1: 语句 1;break; 
case 常量 表达 式 2: 语句 2;break; 
case 常量 表达 式 3: 语句 3;break; 


default: 语 句 N;break; 

} 

控制 表达 式 所 允许 的 数据 类 型 为 sbyte、byte、short、ushort、uint、long、ulong、char、 
string 或 者 枚 举 类 型 。 只 要 使 其 他 不 同 数据 类 型 能 隐 式 转换 成 上 述 的 任何 类 型 ,也 可 以 
将 它 作 为 控制 表达 式 。 
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switch 语句 按 以 下 顺序 执行 。 

(1) 控制 表达 式 求 值 。 

(2) 如 果 case 标签 后 的 常量 表达 式 符合 控制 语句 所 求 出 的 值 ,内 含 语句 被 执行 。 

(3) 如 果 没 有 常量 表达 式 符 合 控 制 语句 ,在 default 标签 内 的 内 含 语句 被 执行 。 

(4) 如 果 没 有 一 个 符合 case 标签 , 且 没 有 default 标签 ,控制 转向 switch 语 段 的 结 

2. 循环 语句 

当 重复 执行 某 些 语句 或 语 段 时 ,依据 当前 不 同 的 任务 .C# 提供 了 4 个 不 同 的 循环 语 
名 : for,foreach、while 和 do。 

1) for 语句 

当 预 先知 道 一 个 内 含 语句 要 执行 多 少 次 时 ,可 以 使 用 for 语句 。 当 条 件 为 真 时 ,常规 
语法 允许 重复 地 执行 内 含 语句 (和 循环 表达 式 )。 

for 语句 格式 如 下 。 

for (初始 化 ;条 件 ;循环 ) 

{ 

语句 ; 

} 

注意 : 初始 化 条件 和 循环 都 是 可 选 的 。 如 果 和 忽略 了 条 件 , 就 产生 一 个 死 循 环 , 要 用 
跳 转 语句 (break 或 goto) 才 能 退出 。 

例如 : 


for (2;) 

{ 

break; // 由 于 某 些 原因 
} 


另外 一 个 重点 是 ,可 以 同时 加 入 多 条 由 逗号 隔 开 的 语句 到 for 循环 的 三 个 参数 中 。 
例如 ,可 以 初始 化 两 个 变量 ,拥有 3 个 条 件 语句 ,并 重复 4 个 变量 。 

2) foreach 语句 

已 经 在 Visual Basic 语言 中 存在 了 很 久 的 一 个 功能 是 ,通过 使 用 foreach 语句 收集 枚 
举 。C# 通 过 foreach 语句 ,也 有 一 个 用 来 收集 枚 举 的 命令 。 

foreach (表达 式 中 的 类 型 标识 符 ) 

{ 

语句 ， 

} 

循环 变量 由 类 型 和 标识 符 声 明 , 且 表达 式 与 收集 相对 应 。 循 环 变量 代表 循环 正在 为 
之 运行 的 收集 元 素 。 不 能 赋 一 个 新 值 给 循环 变量 ,也 不 能 把 它 当 作 ref 或 out 参数 。 

类 必须 支持 具有 GetEnumerator() 名 字 的 方法 ,而 且 由 它 返 回 的 结构 、 类 或 者 接口 必 
须 具 有 public 方法 MoveNext() 和 public 属性 Current 。 
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例如 , 读 所 有 环境 变量 ,如 程序 3-3 所 示 。 
程序 3-3 ”利用 foreach 读 取 环境 变量 


对 GetEnvironmentVariables 的 调用 返回 一 个 IDictionary 类 型 接口 , 它 是 由 . NET 
框架 中 的 许多 类 实现 的 字典 接口 。 通 过 IDictionary 接口 ,可 以 访问 两 个 收集 : Keys 和 
Values。 在 这 个 例子 里 ,在 foreach 语句 中 使 用 Keys, 接 着 查找 基于 当前 键 值 。 

当 使 用 foreach 时 ,要 注意 一 个 问题 : 当 确定 循环 变量 的 类 型 时 ,应 该 格外 小 心 。 选 
择 错 误 的 类 型 且 没 有 受到 编译 器 的 检测 , 它 会 在 运行 时 受 检测 ,将 引发 一 个 异常 。 

3) while 语句 


While( 条 件 ) 
{ 
语句 ; 

} 

条 件 语句 也 是 一 个 布尔 表达 式 ,控制 语句 被 执行 的 次 数 。 可 以 使 用 break 和 contin- 
ue 语句 来 控制 while 语句 中 的 执行 语句 , 它 的 运行 方式 同 在 for 语句 中 的 完全 相同 。 

4) do 语句 

C# 最 后 可 利用 的 循环 语句 是 do 语句 。 它 与 while 语句 十 分 相似 , 仅 当 经 过 最 初 的 
循环 之 后 ,条 件 才 被 验证 。 


语句 ， 
while (条件 ); 


do 语句 保证 语句 至 少 被 执行 过 一 次 ,而 且 只 要 条 件 求 值 等 于 真 ,它们 将 继续 被 执行 。 
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通过 使 用 break 语句 ,可 以 迫使 运行 退出 do 语句 。 如 果 想 跳 过 这 一 次 循环 ,可 以 使 用 
continue 语句 。 

3. 跳 转 语句 

跳 转 语句 包括 break .continue return 和 goto 等 语句 。 

1) break 语句 

(1) 循环 中 遇 到 break 语句 时 ,循环 终止 ,而 程序 控制 流 继续 运行 循环 后 面 的 语句 。 

(2) 内 层 循 环 中 break 语句 只 终止 该 循环 过 程 ,而 外 层 循环 未 受 影 响 。 

(3) break 语句 可 以 与 任意 C# 循环 一 起 使 用 ,其 中 包含 有 意 的 无 限 循环 。 

(4) 一 个 循环 中 可 以 有 多 余 的 break 语句 ,但 此 时 必须 谨慎 , 太 多 的 break 语句 可 能 
拆散 代码 结构 。 

(5) 终止 switch 语句 的 break 语句 只 影响 该 switch 语句 而 不 影响 包含 它 的 外 层 
循环 。 

2) continue 语句 

(1) continue 语句 是 跳出 本 次 循环 中 尚未 执行 的 语句 进入 下 一 次 循环 。 

(2) while 和 do-while 语句 中 ,continue 语句 将 控制 流 直接 跳 到 条 件 表达 式 , 然 后 继 
续 循 环 过 程 。 

(3) for 循环 中 , 先 计算 循环 的 迭代 表达 式 ,执行 条 件 表达 式 ,然后 继续 循环 过 程 。 

3) return 语句 

reture 语句 将 控制 权 返 回 给 方法 的 调用 者 , 它 也 可 以 用 来 返回 值 。 

4) goto 语句 

没有 哪 种 程序 设计 环境 会 要 求 使 用 goto 语句 ,该 语句 不 是 保证 语言 的 完整 性 所 必 
要 的 。 

(1) goto 语句 要 求 有 操作 标签 。 标 签 是 一 个 后 面 带 冒号 *:“ 的 合法 的 C# 标 识 符 。 
另外 ,标签 必须 与 使 用 它 的 goto 语句 处 于 相同 方法 中 。 

(2) goto 语句 的 一 种 较 好 的 使 用 是 用 于 从 深层 艇 套 中 跳出 。 

(3) goto 语句 也 可 以 用 来 跳 转 switch 中 的 case 语句 或 default 语句 。switch 中 的 
case 语句 和 default 语句 其 实 就 是 标签 ,因此 它们 可 以 作为 goto 的 目标 位 置 。goto 语句 
必须 在 switch 内 部 执行 , 即 不 能 使 用 goto 语句 跳 转 到 switch 语句 中 。 


3.2.5 类 


1. 构造 函数 和 析 构 函数 
在 访问 一 个 类 的 方法 、 属 性 或 任何 其 他 内 容 之 前 .第 一 条 执行 的 语句 是 包含 有 相应 类 
的 构造 函数 。 甚 至 不 用 写 一 个 构造 函数 ,也 会 有 一 个 默认 的 构造 函数 提供 给 用 户 。 


class TestClass 

{ 

Public TestClass: base(){} // 有 编译 器 提供 
} 
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一 个 构造 函数 总 是 和 它 的 类 名 相同 ,但 是 , 它 没有 声明 返回 类 型 。 总 之 ,构造 函数 总 
是 public 的 ,可 以 用 它们 来 初始 化 变量 。 


public Testclass() 


{ 
// 初 始 化 变量 代码 等 
} 


如 果 类 仅 包含 静态 成 员 ( 能 以 类 型 调用 ,而 不 是 以 实例 调用 的 成 员 ) ,可 以 创建 一 个 
private 的 构造 函数 。 


Private TestClass () 

{ 

} 

private 意味 着 从 类 的 外 面 不 能 访问 该 构造 函数 。 所 以 , 它 不 能 被 调用 , 且 没 有 对 象 
可 以 自 该 类 定义 被 实例 化 。 

一 个 C/C++ 程序 员 可 能 习惯 于 给 初始 化 写 一 个 附加 的 方法 ,因为 在 构造 函数 中 没有 
返回 值 。 当 然 ,尽管 在 C# 中 也 没有 返回 值 ,但 可 以 引发 一 个 自制 的 异常 ,以 从 构造 函数 
中 获得 返回 值 。 

当 要 释放 引用 的 资源 时 , 写 一 个 可 以 被 显 式 地 调用 来 释放 这 些 资 源 的 方法 。 若 在 
析 构 函数 (以 类 名 的 前 面 加 “一 ”的 方式 命名 ) 中 释放 引用 的 资源 ,需要 写 一 个 附加 的 
方法 。 

public ~TestClass () 

{ 


// 清 除 
} 


写 一 个 附加 方法 的 原因 是 垃圾 收集 器 , 它 在 变量 超出 范围 后 并 不 会 立即 被 调用 ,而 仅 
当 间 吹 期 间或 内 存 条 件 满足 时 才 被 触发 。 当 锁 住 资源 的 时 间 大 于 所 计划 的 时 间 时 , 它 就 
会 发 生 。 因 此 ,一 个 显 式 的 释放 方式 ,最 好 同样 能 从 析 构 函数 中 调用 。 


public void Release () 
{ 

// 释 放 所 有 宝贵 的 资源 
} 

Public ~ TestClass 

{ 

Release(); 

} 


调用 析 构 函数 中 的 释放 方法 并 不 是 必要 的 ,因为 垃圾 收集 器 会 留意 释放 对 象 。 但 不 
忘记 释放 引用 的 资源 是 一 种 良好 的 习惯 。 
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2. 方法 

既然 对 象 能 正确 地 初始 化 和 结束 ,所 剩 下 来 的 工作 就 是 往 类 中 增加 功能 。 在 大 多 数 
情况 下 ,功能 的 主要 部 分 在 方法 中 得 到 实现 。 

1) 方法 参数 

因为 方法 要 处 理 更 改 数值 ,将 值 传 递 给 方法 ,并 从 方法 获得 返回 值 ,所 以 将 涉及 由 
传递 值 和 为 调用 者 获取 返回 结果 所 引起 的 三 方面 的 问题 : 输入 参数 .引用 参数 和 输出 
参数 。 

(1) 输入 参数 。 

一 个 输入 参数 通过 值 传递 一 个 变量 给 一 个 方法 ,方法 的 变量 被 调用 者 传递 来 的 值 的 
一 个 备份 初始 化 ,如 程序 3-4 所 示 。 

程序 3-4 通过 值 传递 参数 


因为 是 传递 值 而 不 是 引用 一 个 变量 ,所 以 当 调用 方法 时 ,可 以 使 用 一 个 常量 表达 式 。 
整 型 结果 被 传 回 给 调用 者 作为 返回 值 , 它 没有 保存 到 中 间 变 量 中 就 被 立即 显示 到 屏幕 上 。 

输入 参数 用 对 于 C/C ++ 程 序 员 早 已 习惯 的 工作 方式 工作 。 如 果 用 户 是 一 个 VB 程 
序 员 ,应 注意 不 能 被 编译 器 处 理 的 隐 式 ByVal 或 ByRef, 如 果 没 有 设 定 ,参数 总 是 用 值 
传递 。 

这 点 似乎 与 前 面 所 陈述 的 有 所 冲突 : 对 于 一 些 变 量 类 型 ,用 值 传 递 实际 上 意味 着 用 
引用 传递 。COM 中 的 东西 就 是 接口 ,每 一 个 类 可 以 拥有 一 个 或 多 个 接口 。 一 个 接口 只 
不 过 是 一 组 函数 指针 , 它 不 包含 数据 ,重复 该 数组 会 浪费 很 多 内 存 资源 。 所 以 . 仅 有 开始 
地 址 被 复制 给 方法 , 它 作 为 调用 者 ,仍然 指向 接口 的 相同 指针 。 这 就 是 对 象 用 值 传递 一 个 
引用 的 原因 。 
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(2) 引用 参数 。 
尽管 可 以 利用 输入 参数 和 返回 值 建立 很 多 方法 ,但 要 传递 值 并 原 地 修改 它 (也 就 是 在 
相同 的 内 存 位置 ) ,这 时 用 引用 参数 比较 方便 。 


void myMethod (ref int nInOut) 
因为 传递 了 一 个 变量 给 方法 ,变量 必须 被 初始 化 ,否则 编译 器 会 报警 。 


程序 3-5 显示 了 如 何 用 一 个 引用 参数 建立 一 个 方法 ,通过 引用 传递 参数 。 
程序 3-5 通过 引用 传递 参数 


正如 所 看 到 的 ,所 有 要 做 的 就 是 给 定义 和 调用 都 加 上 ref 限定 符 。 因 为 变量 通过 引 
用 传递 ,可 以 用 它 来 计算 出 结果 并 传 回 该 结果 。 但 是 ,在 现实 的 应 用 程序 中 ,强烈 建议 要 
用 两 个 变量 ,一 个 作为 输入 参数 , 另 一 个 作为 引用 参数 。 

(3) 输出 参数 。 

传递 参数 的 第 三 种 选择 就 是 把 它 设 为 一 个 输出 参数 。 一 个 输出 参数 仅 用 于 从 方法 传 
递 回 一 个 结果 。 它 和 引用 参数 的 另 一 个 区 别 在 于 : 调用 者 不 必 先 初始 化 变量 才 调用 方 
法 。 如 程序 3-6 所 示 。 

程序 3-6 ”输出 参数 的 应 用 
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2) 改写 方法 

面向 对 象 设计 的 重要 原则 是 多 态 性 。 多 态 性 意味 着 : 当 基 类 程序 员 已 设计 好 用 于 改 
写 的 方法 时 ,在 派生 类 中 ,可 以 重 定义 (改写 ) 基 类 的 方法 。 基 类 程序 员 可 以 用 virtual 关 
键 字 设计 方法 。 


Virtual void CanBOverridden() 
当 从 基 类 派生 时 ,要 做 的 就 是 在 新 方法 中 加 入 override 关键 字 。 
Override void CanBOverridden () 


当 改 写 一 个 基 类 的 方法 时 ,不 能 改变 方法 的 访问 属性 。 
除了 改写 基 类 方法 外 ,还 有 另 一 个 更 重要 的 改写 特性 。 当 把 派生 类 强制 转换 成 基 类 
类 型 并 接着 调用 虚拟 方法 时 ,被 调用 的 是 派生 类 的 方法 而 不 是 基 类 的 方法 。 


((BaseClass)DerivedCclassInstance) .CanBoverridden (); 


为 了 演示 虚拟 方法 的 概念 ,程序 3-7 显示 了 如 何 创建 一 个 三 角形 基 类 , 它 拥有 一 个 可 
以 被 改写 的 成 员 方法 (ComputeArea) 。 
程序 3-7 创建 三 角形 基 类 
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基 类 Triangle 定义 了 方法 ComputeArea。 它 采用 三 个 参数 ,返回 一 个 double 结果 ， 
且 具 有 公共 访问 性 。 从 Triangle 类 派生 出 的 是 RightAngledTriangle, 它 改写 了 Com- 
puteArea 方法 ,并 实现 了 自己 的 面积 计算 公式 。 两 个 类 都 被 实例 化 , 且 在 命名 为 Trian- 
gleTestApp 的 应 用 类 的 Main 方法 中 得 到 验证 。 

其 中 class RightAngledTriangle:Triangle 在 类 语句 中 ,冒号 (: ) 表 示 RightAngled- 
Triangle 从 类 Triangle 派生 。 这 是 必须 要 做 的 .以 让 C# 知道 用 户 要 把 :Triangle 当 作 
RightAngledTriangle 的 基 类 。 当 仔细 观察 直角 三 角形 的 ComputeArea 方法 时 ,会 发 现 
第 三 个 参数 并 没有 用 于 计算 。 但 是 ,利用 该 参数 可 以 验证 是 否 是 “直角 ”, 如 程序 3-8 
所 示 。 

程序 3-8 ”显示 了 如 何 调用 基 类 
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该 检测 简单 地 利用 了 毕 达 哥 拉 斯 公式 ,对 于 直角 三 角形 ,检测 结果 必须 为 0。 如 果 结 
果 不 为 0, 类 将 调用 基 类 的 ComputeArea 来 实现 。 


dArea=base. ComputeArea (a,b,c); 


上 例 说 明了 通过 显 式 地 利用 基 类 的 资格 检查 ,可 以 轻而易举 地 调用 基 类 实现 改写 方 
法 。 当 需要 实现 在 基 类 中 的 功能 而 不 愿意 在 改写 方法 中 重复 它 时 ,这 是 非常 有 帮助 的 。 

3) 方法 屏蔽 

重 定义 方法 的 一 个 不 同 之 处 就 是 要 屏蔽 基 类 的 方法 。 当 从 别人 提供 的 类 派生 类 时 ， 
这 个 功能 特别 有 用 。 在 下 例 中 假设 BaseClass 是 由 他 人 所 写 ,而 用 户 需要 从 它 派生 出 De- 
rivedClass。 如 程序 3-9 所 示 。 

程序 3-9 利用 DerivedClass 实现 了 一 个 没有 包含 于 BaseClass 中 的 方法 


若 有 修饰 符 new, 则 可 以 告诉 编译 器 不 必 重 写 派生 类 或 改变 使 用 到 派生 类 的 代码 ,用 
户 的 方法 将 能 屏蔽 新 加 入 的 基 类 方法 。 如 程序 3-10 所 示 。 
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程序 3-10 如何 运用 new 修饰 符 及 如 何 屏 项 基 类 方法 


使 用 了 附加 的 new 修饰 符 ,编译 器 就 知道 重 定义 了 基 类 的 方法 , 它 应 该 屏蔽 原来 的 
基 类 方法 。 但 是 ,如 果 按 以 下 方式 编写 : 

DerivedClass test=new DerivedClass(); 

((BaseClass)test) .TestMethod (); 
基 类 方法 的 实现 就 被 调用 了 。 这 种 行为 不 同 于 改写 方法 ,后 者 保证 了 大 部 分 派生 方法 能 
获得 调用 。 

3. 类 属性 

有 两 种 途径 揭示 类 的 命名 属性 ,通过 域 成 员 或 者 通过 属性 。 前 者 是 作为 具有 公共 访 
问 性 的 成 员 变量 而 被 实现 的 ,后 者 并 不 直接 回应 存储 位 置 ,只 是 通过 存 取 标志 (accessors) 
被 访问 。 

当 想 读 出 或 写 人 属性 的 值 时 . 存 取 标志 限定 了 被 实现 的 语句 。 用 于 读 出 属性 值 的 存 
取 标 志 记 为 关键 字 get, 而 要 修改 属性 值 的 读 写 符 标 志 记 为 get, 如 程序 3-11 所 示 。 

程序 3-11 实现 属性 存 取 标 志 
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House 类 有 一 个 命名 为 SquareFeet 的 属性 , 它 可 以 被 读 写 。 实 际 的 值 存 储 在 一 个 可 
以 从 类 内 部 访问 的 变量 中 ,如 果 想 当 作 一 个 域 成 员 重 写 , 所 要 做 的 就 是 忽略 存 取 标 志 而 把 
变量 重新 定义 为 ， 


Public int SquareFeet7 


对 于 一 个 简单 的 变量 可 以 这 样 定义 。 但 是 ,如 果 想 要 隐藏 类 内 部 存储 结构 的 细节 时 ， 
就 应 该 采用 存 取 标志 。 在 这 种 情况 下 ,set 存 取 标志 给 值 参 数 中 的 属性 传递 新 值 。 

除了 能 够 隐藏 实现 细节 外 ,还 可 自由 地 限定 各 种 操作 。get 和 set 允许 对 属性 进行 读 
写 访问 ;get only 只 允许 读 属性 的 值 ;set only 只 允许 写 属性 的 值 。 

4. 索引 

使 用 C# 的 索引 功能 可 以 像 访 问 数组 那样 使 用 索引 访问 类 。 

语法 基本 如 下 : 


属性 修饰 符 声明 {声明 内 容 } 
有 具体 的 例子 为 : 


public string this [int nIndex] 
{ 

getf 

ET 

} 


索引 返回 或 按 给 出 的 index 设置 字符 串 。 它 没有 属性 ,但 使 用 了 Public 修饰 符 。 声 
明 部 分 由 类 型 string 和 this 组 成 用 于 表示 类 的 索引 。 

get 和 set 的 执行 规则 和 属性 的 规则 相同 ,只 存在 一 个 差别 , 那 就 是 ,几乎 可 以 任意 定 
义 大 括号 中 的 参数 。 限 制 为 必须 至 少 规定 一 个 参数 ,允许 ref 和 out 修饰 符 。 

this 关键 字 确 保 一 个 解释 。 索 引 没有 用 户 定 义 的 名 字 ,this 表示 默认 接口 的 索引 。 
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如 果 类 实现 了 多 个 接口 ,可 以 增加 更 多 个 由 InterfaceName this 说明 的 索引 。 

5. 事件 

当 写 一 个 类 时 ,有 时 有 必要 让 类 的 客户 知道 一 些 已 经 发 生 的 事件 。 如 果 是 一 个 具有 
多 年 编程 经 验 的 程序 员 , 可 以 有 很 多 解决 办 法 ,包括 用 回调 的 函数 指针 和 用 ActiveX 控件 
的 事件 接收 Cevent sinks)。 下 面 将 介绍 另外 一 种 把 客户 代码 关联 到 类 通知 的 方法 一 一 使 
用 事件 。 

事件 既 可 以 被 声明 为 类 域 成 员 ( 成 员 变 量 ), 也 可 以 被 声明 为 属性 。 两 者 的 共性 为 : 
事件 的 类 型 必定 是 代表 元 ,而 函数 指针 原型 和 C# 的 代表 元 具有 相同 的 含义 。 

每 一 个 事件 都 可 以 被 一 个 或 多 个 客户 占用 , 且 客 户 可 以 随时 关联 或 取消 事件 。 可 以 
以 静态 或 者 以 实例 方法 定义 代表 元 ,而 后 者 很 受 C ++ 程 序 员 的 欢迎 。 程 序 3-12 显示 如 何 
在 类 中 实现 事件 处 理 。 

程序 3-12 在 类 中 实现 事件 处 理 
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public void InstanceCatch (string strText) 
{ 

Console.WriteLine ("Instance"+ strText); 
} 
J 


TestApp 类 包含 了 Main 方法 ,也 包含 了 另外 两 个 方法 ,它们 都 具备 事件 所 必需 的 信 
号 。 其 中 一 个 方法 是 静态 的 ,而 另 一 个 是 实例 方法 。 

EventSource 被 实例 化 ,而 静态 方法 CatchEvent 被 关联 上 了 TextOut 事件 。 

Evsrc.TextOut+=new EventHandler (theApp.InstanceCatch); 

从 现在 起 , 当 事 件 被 触发 时 ,该 方法 被 调用 。 如 果 对 事件 不 再 感 兴趣 ,可 以 取消 关联 。 

event .TextOut-=new EventHandler (CatchEvent); 

为 了 证 明 事件 处 理 函 数 也 和 实例 方法 一 起 工作 ,余下 的 代码 建立 了 TestApp 的 实 
例 , 并 关联 事件 处 理 方法 。 

在 ASP. NET 中 会 经 常 涉及 事件 和 代表 元 。 


3.3 ASP.NET 控件 


ASP. NET 的 强大 功能 和 便捷 离 不 开工 具 箱 控件 的 支持 。 控 件 可 分 为 标准 控件 、 数 
据 控件 ,验证 控件 、 导 航 控件 、 登 录 控件 、WebParts 控件 .HTML 控件 和 水 晶 报表 控件 等 。 
用 户 可 以 用 两 种 方法 添加 控件 : 从 工具 箱 直 接 拖 放 控 件 到 Web 页 面 ;通过 添加 相应 代码 
添加 控件 。 


3.3.1 Web 窗 体 的 标准 控件 


1. 单 选 控件 和 单 选 组 控件 (RedioButton 和 RedioButtonList) 

单 选 控件 的 选择 只 能 有 一 种 。 凡 是 从 有 限 种 可 能 性 中 ,只 能 选择 一 种 结果 时 ,都 可 以 
用 单 选 控件 来 实现 。 单 选 控件 通过 Checked 属性 来 判断 是 否 被 选中 。 多 个 单 选 控件 之 
间 可 以 存在 着 联系 ,此 时 单 选 控件 通过 GroupName 属性 来 对 这 些 控 件 约束 和 联系 , 它 用 
来 指明 多 个 单 选 控件 是 否 是 在 同一 条 件 下 的 选择 项 。 对 GroupName 相同 的 多 个 单 选 控 
件 之 间 , 只 能 有 一 个 被 选中 。 单 选 控件 最 常用 的 事件 是 CheckChanged。 当 控件 选中 状态 
改变 时 ,将 会 激发 该 事件 。 下 面 来 看 两 个 应 用 实例 。 

1) 单 选 控件 应 用 实例 

在 工具 箱 中 选中 单 选 控件 , 拖 曙 三 个 单 选 按钮 到 窗 体 上 ,然后 利用 属性 窗口 ,设置 单 
选 按钮 如 表 3-3 所 示 的 属性 。 
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表 3-3 单 选 按钮 控件 属性 


属 性 值 属 性 值 
Check False GroupName color 
rbChoosel 红色 
ID rbChoose2 Text 蓝 色 
rbChoose3 绿色 


对 每 个 单 选 按钮 编写 相应 的 代码 ,如 程序 3-13 所 示 。 
程序 3-13 ” 单 选 按钮 对 应 的 代码 


运行 本 程序 的 效果 如 图 3-16 所 示 。 
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2) 单 选 组 控件 应 用 实例 
在 工具 箱 中 选中 RadioButtonList 控件 ,将 其 拖 放 到 窗 体 上 。 然 后 利用 属性 窗口 设 
置 属 性 ,如 表 3-4 所 示 。 


汪 无 标题 页 - Hicrosoft Internet Ezplorer ” 色 | 右 | 区 | 
文件 叶 ) 编辑 证 ) 查看 外 收 总 和 工具 CD) 帮助 加 EE 


@ 红 -日 `- 国 国信 | 时 直 Wex “ 表 3-4 单 选 组 控件 属性 
地 址 四) | 倒 http://ocahost:105U 圈 | 园 辕 到 时 smert 国志 属 性 值 
AutoPostBack True 
ID rblBackColor 


本 地 Intranet 


图 3-16 单 选 按钮 效果 图 


同时 在 窗口 上 放置 一 个 标签 控件 ,ID 属性 设置 为 lbText, Text 属性 设置 为 “实验 
文本 ”。 

窗 体 的 HTML 代码 如 程序 3-14 所 示 。 

程序 3-14 ” 单 选 组 控件 对 应 的 HTML 代码 


< form id= "forml”runat= "server"> 
<div> 
<asp:RadioButtonList ID= "rblBackColor" runat= "serVer"”RutoPostBack= "True" Style="z 
— index: 100; left: 167px; position: absolute; top: 84px" OnSelectedIndexChanged 
="rblBackColor SelectedIndexChanged"> 
<asp:ListItem Value= "3"> 红 色 背 景 < /asp:ListItem> 
<asp:ListItem Value= "4"> 蓝 色 背 景 < /asp:ListItem> 
<asp:ListItem Value= "5"> 绿 色 背 景 < /asp:ListItem> 
</asp:RadioButtonList> 
<asp:Label ID="lbText" runat="server" Style="z- index: 102; left: 337px; Position: 
absolute;top: 115px" Text=" 实 验 文本 ">< /asp:Label> 
</div> 
</form> 


双击 RadioButtonList 控件 ,对 SelectedIndexChanged 事件 进行 编程 ,使 得 对 RadioBut- 
tonList 中 每 个 单 选 按钮 的 每 次 选择 ,都 同时 改变 标签 文本 的 背景 色 。 如 程序 3-15 所 示 。 
程序 3-15 单 选 组 控件 实例 对 应 的 . CS 代码 


protected void rblBackColor SelectedIindexChanged (object sender, EventArgs e) 
{ 
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// 如 果 选 中 了 第 一 个 按钮 , 则 改变 标签 文本 相应 背景 色 为 红色 
if (this.rblBackColor.SelectedIndex==0) 
. 
this.lbText .BackColor=Color .Red; 
: 
// 如 果 选 中 了 第 二 个 按钮 , 则 改变 标签 文本 相应 背景 色 为 蓝 色 
else if (this.rblBackColor.SelectedIndex==1) 
this.lbText .BackColor=Color.Blue; 
} 
// 如 果 选中 了 第 三 个 按钮 , 则 改变 标签 文本 相应 背景 色 为 绿色 
else if (this.rblBackColor.SelectedIndex==2) 
{ 
this.lbText.BackColor=Color.Green; 


} 


程序 执行 效果 如 图 3-17 所 示 。 


与 无 标题 页 - Microsoft Internet Explorer 
文件 @) 编辑 于 查看 WD 收 襄 A) 工具 CI) 和 助 0 


@ia-©O- 国 国 的 Ps tnx 加 | 四 
[TI 


〇 红色 背景 
〇 蓝 色 背景 
@ 绿 色 背景 


图 3-17 单 选 组 按钮 效果 图 


2. 复 选 控件 和 复 选 组 控件 (CheckBox 和 CheckBoxList) 

当 录 入 的 信息 具有 很 多 种 可 能 时 , 单 选 控件 就 不 再 满足 需要 了 。 此 时 ,可 以 使 用 
CheckBox 复 选 框 控件 ,使 多 种 可 能 性 可 以 同时 被 选择 。 复 选 框 控件 同样 依靠 Checked 
属性 来 判断 是 否 被 选中 。 下 面 是 复 选 控件 的 应 用 实例 。 

在 工具 箱 中 选择 复 选 控件 .拖拉 三 个 复 选 框 至 窗 体 上 ,同时 放置 一 个 Label 控件 , 设 
置 其 Text 属性 为 “示例 文本 ”.ID 为 lbText, 利 用 属性 窗口 来 设置 其 他 控件 属性 ,如 表 3-5 
所 示 。 

在 设计 窗 体 页 面 ,逐个 双击 复 选 按钮 。 每 次 双击 都 会 添加 对 应 复 选 框 的 CheckChanged 
事件 。 用 户 也 可 以 在 复 选 按钮 属性 页 中 添加 CheckChanged 事件 。 如 程序 3-16 所 示 。 
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表 3-5 复 选 框 控件 属性 


属 性 值 属 性 值 
Checked False AutoPostBack True 
cbChoosel 文字 具有 上 划 线 
ID cbChoose2 Text 文字 具有 下 划 线 
cbChoose3 文字 具有 删除 线 


程序 3-16 ” 复 选 控件 实例 对 应 的 . CS 代码 
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this.lbText.Font .Strikeout= false; 


I 


程序 执行 效果 如 图 3-18 所 示 。 


怠 无 标题 页 - Nicrosoft Internet Explorer 回回 | 加 | 
文件 四 编辑) 查看 W) 收藏 A) 工具 GD) 帮助 0D 


@ 右 - 日 , 因 国 纹 记 暴 区 mx 思 站 -学 


地 址 凤 | 俩 http://1ocalhost:1051/Webcontrols/checd 圈 | 回填 到 名 smaert 图 国 


» 


回 文字 具有 上 划 线 
回 文字 具有 下 划 线 
回 文字 具有 考 除 线 


本 地 Intranet 


图 3-18 复 选 框 控件 效果 图 


3. 列表 控件 (DropDownList、ListBox 和 BulletedList) 

列表 控件 可 以 在 一 个 控件 框 内 为 用 户 提 供 多 个 选项 。 最 常用 的 列表 控件 是 Drop- 
DownList, 其 次 还 有 ListBox、BulletedList 控件 可 选择 。DropDownList、ListBox 和 Bul- 
letedList 控件 都 以 HTML 的 二 select 二 标签 来 显示 到 浏览 器 上 ,列表 控件 中 的 项 由 List- 
Item 表示 ,Text 指定 代表 列表 控件 项 的 文本 ,Value 则 是 与 该 项 关联 的 值 。ListItem 还 
有 一 个 Selected 的 属性 , 它 表 示 该 项 是 否 被 选中 。 下 面 是 列表 控件 应 用 实例 。 

在 工具 箱 中 选择 DropDownList, 将 其 拖 放 至 窗 体 上 ,设置 属性 如 表 3-6 所 示 。 

在 工具 箱 中 选择 ListBox, 将 其 拖 放 至 窗 体 上 ,利用 属性 窗口 设置 属性 如 表 3-7 所 示 。 


表 3-6 ”DropDownList 控件 属性 表 3-7 ListBox 控件 属性 
属 性 值 属 性 值 
ID ddMusic ID lbChoose 
AutoPostBack True AutoPostBack True 
Text Value Text Value 
儿歌 0 小 说 0 
Ttem 流行 音乐 1 散文 
古典 音乐 2 Item 议论 文 2 
稻 士 乐 3 诗歌 3 
蓝调 音乐 4 译 著 4 
杂文 5 
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在 工具 箱 中 选择 BulletedList, 将 其 拖 放 至 窗 体 上 ,利用 属性 窗口 设置 属性 如 表 3-8 
所 示 。 
表 3-8 ”BulletedList 控件 属性 
属 性 值 
D blListChoose 


在 设计 窗 体 上 ,同时 放置 一 个 Label 控件 ,ID 为 lbText。 在 示例 程序 中 ,将 使 用 La- 
bel 控件 来 显示 用 户 选择 了 什么 内 容 。 如 程序 3-17 所 示 。 
程序 3-17 列表 控件 实例 所 对 应 的 . CS 代码 


程序 运行 效果 如 图 3-19 所 示 。 
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马 无 标题 页 - 了 icrosoft Internet Exzplorer 
文件 下 ) 编辑) ”查看 WD 收 总 由 工具 中 ”帮助 中 


Ga .日 日 介 | Per Wms @ | 全 -DS 


3-19 列表 控件 显示 效果 图 


3.3.2 Web 窗 体 的 数据 控件 


1. 数据 源 控件 
ASP.NET 包含 一 些 数据 源 控件 ,这 些 数 据 源 控件 允许 使 用 不 同类 型 的 数据 源 , 如 数 
据 库 、XML 文件 或 中 间 层 业务 对 象 。 数 据 源 控件 连接 到 数据 源 , 从 中 检索 数据 ,并 使 其 
他 控件 可 以 绑 定 到 数据 源 而 无 须 代 码 。 数 据 源 控件 还 支持 修改 数据 。 
.NET Framework 包含 支持 不 同 数据 绑 定 方案 的 数据 源 控件 。 表 3-9 描述 了 内 置 的 
数据 源 控件 。 
表 3-9 数据 源 控件 


数据 源 控件 说 明 

允许 使 用 业务 对 象 或 其 他 类 ,以 及 创建 依赖 中 间 层 对 象 管理 数据 的 Web 应 用 

程序 。 支 持 对 其 他 数据 源 控件 不 可 用 的 高 级 排序 和 分 页 方案 

允许 使 用 Microsoft SQL Server、OLE DB、ODBC 或 Oracle 数据 库 。 与 SQL 

SqlDataSource Server 一 起 使 用 时 支持 高 速 缓存 功能 。 当 数据 作为 DataSet 对 象 返回 时 ,此 

控件 还 支持 排序 .筛选 和 分 页 

Nena 允许 使 用 Microsoft Access 数据 库 。 当 数据 作为 DataSet 对 象 返回 时 ,支持 排 
序 ,筛选 和 分 页 

允许 使 用 XML 文件 ,特别 适用 于 分 层 的 ASP. NET 服务 器 控件 ,如 TreeView 

XmlDataSource 或 Menu 控件 。 支 持 使 用 XPath 表达 式 来 实现 筛选 功能 ,并 允许 对 数据 应 用 
XSLT 转换 。XmlDataSource 允许 通过 保存 更 改 后 的 整个 XML 文档 来 更 新 

数据 


SiteMapDataSource “| 结合 ASP. NET 站 点 导航 使 用 


ObjectDataSource 


2. Repeater 控件 
Repeater 是 一 个 可 重复 操作 的 控件 , 它 通过 使 用 模板 显示 一 个 数据 源 的 内 容 , 而 且 
用 户 可 以 很 容易 地 配置 这 些 模板 。Repeater 控件 包含 如 标题 和 页 脚 这 样 的 数据 , 它 可 以 
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遍历 所 有 数据 选项 并 将 其 应 用 到 模板 中 。 

Repeater 控件 并 不 是 由 WebControl 类 派生 而 来 的 ,所 以 它 不 包括 一 些 通用 的 格式 
属性 。 但 是 可 以 通过 直接 操纵 HTML 或 者 ASP. NET 类 来 处 理 这 些 属性 。 以 下 代码 简 
单 地 声明 一 个 Repeater 控件 。 


<asp:Repeater id= "MyRepeater" runat= "server">< /asp:Repeater> 


1) 使 用 模板 

在 Web 设计 窗口 ,Repeater 控件 显示 为 一 个 方 框 ,并 有 如 下 提示 :“ 切 换 到 HTML 
视图 编辑 该 控件 模板 ”。Repeater 控件 只 支持 模板 , 它 有 如 下 模板 可 供 选 择 。 

。 AlternatingItemTemplate: 指定 如 何 显示 每 一 个 其 他 选项 。 
ItemTemplate: 指定 如 何 显示 选项 。 

。 HeaderTemplate: 建立 如 何 显示 标题 。 

。 FooterTemplate: 建立 如 何 显示 页 脚 。 

。 SeparatorTemplate: 指定 如 何 显示 不 同 选项 之 间 的 分 隔 符 。 

用 户 可 以 使 用 这 些 模 板 来 显示 数据 。 唯 一 具有 强制 性 的 模板 是 ItemTemplate, 其 他 
模板 都 是 具有 可 选 性 的 。 

2) 绑 定数 据 源 

对 于 数据 源 ,Repeater 控件 通过 属性 中 的 DataSource 属性 获得 或 者 设置 Repeater 
显示 提供 数据 源 。 通 过 DataMember 属性 获取 或 者 设置 与 Repeater 控件 绑 定 相 应 的 
DataSource 属性 表格 。 所 有 这 些 操作 ,也 可 以 通过 相应 页 面 中 的 编程 实现 。 

3) 常用 事件 

Repeater 控件 最 常用 的 事件 包括 ItemCommand ItemCreater 和 ItemDataBound。 
当 创建 一 个 项 或 者 一 个 项 被 绑 定 到 数据 源 时 ,将 分 别 激 发 ItemCreated 和 Item- 
DataBound 事件 。 当 Repeater 控件 中 有 按钮 被 单 击 时 ,将 激发 temCommand 事件 。 在 
ItemCommand 事件 中 ,用 户 可 以 通过 RepeaterCommandEventArgs 参数 获取 Command- 
Argument .CommandName 和 CommandSource 属性 的 值 。 通 过 这 些 属性 可 以 获得 在 
Repeater 中 按钮 控件 的 名 称 、 值 等 。 

下 面 是 Repeater 控件 应 用 实例 ,程序 3-18 显示 使 用 Repeater 控件 输出 图 书目 录 。 
核心 代码 如 下 。 

程序 3-18 ”使 用 Repeater 控件 输出 图 书目 录 


<asp:Repeater ID= "Repeaterl" runat= "server" DataSourceID= "SqlDataSourcel"> 
< ItemTemplate> 
“<a href="Book.aspx?SortID=<%#Eval ("SortID") %$>"> 
<$S#Eval ("SortName")®% >< /a> 
<br /> 
</ItemTemplate> 
</asp:Repeater> 
<asp:SqlDataSource ID= "SqlDataSourcel"” runat= "server" 
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Connectionstring="<%$ ConnectionStrings:EnglishViewConnectionString 当 >" 
SelectCommand= "SELECT [SortID], [SortName] FROM [BookSort] ORDER BY [SortPRI]"> 
< /asp:SqlDataSource> 


运行 结果 如 图 3-20 所 示 。 rusNuwuto 区 
3. DataList 控件 EE 


DataList 控件 与 Repeater 控件 在 很 多 方面 都 很 相似 .但 ”| … 全 烽 续 给 英语 
是 它 也 具有 一 些 Repeater 不 具有 的 属性 ,特别 是 它 增加 了 | “生生 人 
对 多 列 格式 、 项 选择 和 项 编辑 的 支持 。DataList 控件 支持 各 ”| “中 学 英语 阅读 微 技能 训练 
种 不 同 的 模板 和 样式 ,通过 为 DataList 控件 的 不 同 部 分 指定 
样式 ,可 以 自 定义 该 控件 的 外 观 。 

1) 使 用 模板 

在 上 一 部 分 已 经 介绍 过 Repeater 控件 的 5 个 模板 (ItemTemplate、AlternatingItem- 
Template SeparatorTemplate、 HeaderTemplate 和 FooterTemplate) ,可 以 格式 化 控件 的 
输出 。 在 DataList 控件 中 除了 支持 Repeater 控件 中 的 5 个 模板 以 外 ,还 支持 如 下 两 个 
模板 。 

。 SelectedItemTemplate: 控制 如 何 格式 化 被 选 定 的 项 。 

”EditItemTemplate: 控制 如 何 格式 化 被 编辑 的 项 。 

当 在 DataList 中 选中 一 个 项 时 ( 即 DataList 的 SelectedIndex 属性 值 为 当前 选 定 项 
的 索引 值 ) ,将 显示 SelectedItem 模板 ; 当 在 DataList 中 选择 一 个 项 来 编辑 ( 即 DataList 
的 EditItemIndex 属性 值 为 当前 选 定 项 的 索引 值 ) 时 ,将 显示 EditItem 模板 。 

2) 在 DataList 中 显示 数据 

可 以 像 Repeater 控件 那样 来 用 DataList 显示 数据 库 表 中 的 记录 。 但 是 ,与 Repeater 
控件 不 同 的 是 ,DataList 控件 的 默认 行为 是 在 HTML 表格 中 显示 数据 库 记 录 。 

3) 在 DataList 中 创建 多 列 

DataList 的 一 个 好 的 特征 是 可 以 以 多 个 列 显 示 数 据 项 。 通 过 设置 其 RepeatColumns 
和 RepeatDirection 属性 ,可 以 控制 DataList 列 的 布局 。 

RepeatColumns 属性 决定 要 显示 列 的 数量 。 例 如 ,如 果 要 在 DataList 中 显示 4 列 的 
项 ,那么 可 以 把 这 个 属性 设 为 4。 

RepeatDirection 属性 是 按 水 平 或 垂直 方向 来 重复 。 在 默认 情况 下 ,RepeatDirection 
值 为 Vertical ,因此 ,如 果 RepeatColumns 值 为 4, 则 列 就 如 下 显示 。 


3-20 ”Repeater 控件 显示 
数据 效果 图 


Column 1 Column3 Column5 Column7 

Column 2 Column4 Column6 Column8 

如 果 把 RepeatDirection 设 为 Horizontal, 而 且 RepeatColumns 值 为 4, 那 么 列 就 如 下 
显示 。 

Column 1 Column3 Column5 Column7 

Column 2 Column4 Column6 Column8 


注意 : 即使 RepeatDirection 值 为 Vertical, 还 是 显示 为 4 个 列 。RepeatColumns 永 


第 3 章 ASPNET 基 础 105 


远 是 指 重复 列 的 数量 ,而 不 是 行 的 数量 。 

4) DataList 控件 支持 5 个 事件 

。 EditCommand: 由 带 有 CommandName 王 "edit" 的 子 控 件 产 生 。 

。 CancelCommand: 由 带 有 CommandName 王 "cancel" 的 子 控件 产生 。 

。 UpdateCommand: 由 带 有 CommandName 王 "update" 的 子 控件 产生 。 

。 DeleteCommand: 由 带 有 CommandName 王 "delete" 的 子 控件 产生 。 

。 ItemCommand: DataList 的 默认 事件 。 

在 ASP. NET 中 有 三 个 控件 带 有 CommandName 属性 ,分 别 是 Button、LinkButton 
和 ImageButton, 可 以 设置 它们 的 CommandName 属性 来 表示 容器 控件 内 产生 的 时 间 类 
型 。 例 如 ,如 果 设 置 DataList 中 的 一 个 LinkButton 的 CommandName 属性 为 update, 那 
么 单 击 此 按钮 时 ,将 会 触发 DataList 的 CancelCommand 事件 ,我 们 可 以 将 相关 处 理 代码 
写 到 对 应 的 事件 处 理 程序 中 去 。 

4. GridView 控件 


GridView 控件 是 功能 非常 丰富 的 控件 。 此 控件 采用 表格 形式 显示 从 数据 库 中 获取 


的 数据 集合 。 

1) 外 观 和 格式 ET 

要 定制 GridView 的 格式 十 分 简单 ,只 需要 用 鼠标 单 | | FE 
击 GridView, 在 弹出 的 菜单 中 选择 “自动 套用 格式 ”, 则 可 | 8 
以 选择 GridView 的 样式 。GridView 控件 内 置 了 许多 样 | 经; 
式 , 如 图 3-21 所 示 。 

和 海 漂 和 天 空 

如 果 要 对 GridView 中 每 一 列 自 定义 格式 , 则 只 需 单 | 又 
击 GridView 右上 角 的 “智能 标记 ”三 角 符号 .在 弹出 的 菜 | 可 
单 中 选择 “编辑 列 ”, 则 会 弹出 如 图 3-22 所 示 的 窗 体 ,这 样 。| | 到 


就 可 以 对 每 列 进行 详细 的 设置 。 例 如 ,添加 “编辑 "“ 更 新 ” 
和 “取消 "等 按钮 。 
2) 数据 绑 定 图 3-21 自动 套用 格式 
GridView 控件 通过 数据 源 控件 自动 绑 定 和 显示 数据 。 
通过 数据 源 控件 对 数据 进行 选择 、 排 序 、 分 页 ,编辑 和 删除 。 
GridView 控件 提供 两 个 用 于 数据 绑 定 的 选项 。 
。 DataSourceID 属性 : 此 选项 能 够 将 GridView 控件 绑 定 到 数据 源 控件 。 它 允许 
GridView 控件 利用 数据 源 控件 的 功能 并 提供 了 内 置 的 排序 分 页 和 更 新 功能 。 
。 DataSource 属性 : 此 选项 包括 ADO. NET 数据 集 和 数据 读 取 器 在 内 的 各 种 对 象 ， 
此 方法 需要 为 所 有 附加 功能 (如 排序 ,分 页 和 更 新 ) 编 写 代码 。 
3) 常用 事件 
GridView 控件 包含 许多 事件 .其 中 常用 的 有 RowDeleting、RowEditing、RowUpdat- 
ing、RowDeleted 和 RowUpdated 等 。 通 过 这 些 常 用 属性 ,可 以 灵活 地 实现 多 种 功能 。 
程序 3-19 是 用 GridView 控件 对 数据 进行 操作 的 例子 。 本 实例 是 通过 使 用 Grid- 
View 对 图 书 进行 管理 。 
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可 用 字段 和 ); BoundField 属性 中) 


国 BounaField 国 呈 | 


国 chechBorField | 
HyperLinkield 日 可 访问 性 
加 imagepiaa AccessiblelesderText 
国 Bottonriaa 日 数 括 
由 国 commandFisld DataField SertEame 
a) TenplateField DataFormatString 
日 外 观 
FooterText 
HeaderInagelrl 
HeaderText 分 类 名 称 
日 行为 
ApplyFornatInEdi tlode False 


esderTert 
此 字段 的 标 头 内 的 文本 。 


口 生成 了 及 回 EECTTTERSRR 
li 7 


3-22 ” 自 定 义 格式 


程序 3-19 ”使 用 GridView 控件 对 数据 进行 显示 


< asp: GridView ID="GridViewl" runat="server" DataSourceID="SqlDataSourcel" Width=" 
700px" AutoGenerateColumns= "False" AllowPaging= "True"> 

<Columns> 

<asp:BoundField DataField= "SortName" HeaderText=" 分 类 名 称 " SortExpression= "SortName" 
/> 

<asp:BoundField DataField= "BookPRI" HeaderText= "图 书 优先 级 ” SortExpression= "BookPRI" 
/> 

<asp:BoundField DataField= "BookName"” HeaderText=" 书 名 " SortExpression= "BookName" /> 
<asp:BoundField DataField= "BookPublish" HeaderText=" 出 版 社 " SortExpression= "BookPub - 
lish" /> 

<asp:BoundField DataField= "BookVariety” HeaderText=" 品 种 " SortExpression="BookVari- 
ety" /> 

<asp:BoundField DataField= "BookPrice" HeaderText=" 定 价 " SortExpression= "BookPrice”" /> 
<asp:BoundField DataField= "BookSupply”HeaderText=" 供 货 " SortExpression="BookSupply" 
六 

< asp: HyperLinkField HeaderText= "编辑 ”Text=" 编 辑 ”" DataNavigateUrlFields="BookID, 
SortID" DataNavigateUrlFormatString= "BookEdit .aspx? BookID= {0}&amp; SortID= {1}"/> 

< asp: HyperLinkField HeaderText=" 删 除 ” Text=" 删 除 " DataNavigateUrlFields="BookID, 
SortID" DataNavigateUrlFormatString= "BookDel .aspx? BookID= {0}&amp; SortID= {1}"/> 
<asp:HyperLinkField HeaderText= "添加 "Text=" 添 加" DataNavigateUrlFields="SortID" Da- 
taNavigateUrlFormatString= "BookAdd.aspx? SortID= {0}"/> 

< /Columns> 

< /asp:GridView> 
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< asp: SqlDataSource ID =" SqlDataSourcel" runat =" server" ConnectionString =" <% 
$ ConnectionStrings:EnglishViewConnectionString %$>" 
SelectCommand= "SELECT BookSort. SortName, BookInfo.BookID, BookInfo.SortID, BookInfo. 
BookPRI, BookInfo.BookName, BookInfo.BookVariety, BookInfo.BookPublish, BookInfo.Book- 
Price, BookInfo.BookSupply FROM BookInfo INNER JOIN BookSort ON BookInfo. SortID= Book- 
Sort.SortID where (BookInfo. [SortID]=@ SortID) ORDER BY BookInfo.BookPRI"> 

<SelectParameters> 

<asp:QueryStringParameter Name= "SortID" QueryStringField= "SortID" /> 

< /SelectParameters> 

</asp:SqlDataSource> 


运行 结果 如 图 3-23 所 示 。 


图 书 管理 
2 书 名 出 版 让 品种 “定价 
bl 
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图 3-23 ”使 用 GridView 控件 显示 数据 效果 图 


3.3.3 验证 控件 


验证 控件 是 ASP.NET 引入 的 一 种 新 型 服务 器 控件 , 它 可 以 验证 服务 器 控件 中 用 户 
的 输入 ,并 且 在 验证 失败 的 情况 下 可 以 显示 一 条 自 定义 消息 。 验 证 是 在 客户 端 直接 进行 ， 
避免 用 户 提交 后 ,再 由 服务 器 返回 错误 信息 的 交互 过 程 。ASP. NET 中 的 验证 控件 如 
表 3-10 所 示 。 

表 3-10 6 种 验证 控件 


控 件 名 功能 描述 
RequiredFieldValidator( 必 须 字 段 验证 ) 用 于 检查 是 否 有 输入 值 
CompareValidator( 比 较 验 证 ) 按 设 定 比 较 两 个 输入 
RangeValidator( 范 围 验证 ) 输入 是 否 在 指定 范围 
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续 表 
控 件 名 功能 描述 
RegularExpressionValidator( 正 则 表达 式 验 证 ) 正则 表达 式 验证 控件 
CustomValidator( 自 定义 验证 ) 自 定义 验证 控件 
ValidationSummary( 验 证 总 结 ) 总 结 验证 结果 


1. RequiredFieldValidator 控件 
控件 RequiredFieldValidator 使 用 的 标准 代码 如 下 : 


<ASP:RequiredFieldValidator id= "Validator Name" Runat="Server" 
ControlToValidate= "要 检查 的 控件 ID" 
ErrorMessage= "出 错 信息 " 
Display= "Staticl1Dymatic|None” 

Fs 


占 位 符 
< /ASP: RequiredFieldValidator > 


在 以 上 标准 代码 中 ,ControlToValidate 表示 要 进行 检查 控件 ID;ErrorMessage 表示 
当 检 查 不 合法 时 ,出 现 的 错误 信息 ;Display 表示 错误 信息 的 显示 方式 ;Static 表示 控件 的 
错误 信息 在 页 面 中 占有 肯定 位 置 ;Dymatic 表示 控件 错误 信息 出 现时 才 占 用 页 面 控件 ; 
None 表示 错误 出 现时 不 显示 ,但 是 可 以 在 ValidatorSummary 中 显示 ; 占 位 符 表示 Dis- 
play 为 Static 时 ,错误 信息 占有 占 位 符 那 么 大 的 页 面 空间 。 

2. CompareValidator 控件 

比较 两 个 控件 的 输入 是 否 符合 程序 设 定 ,标准 代码 如 下 : 


<ASP:CompareValidator id= "Validator ID” RunAt= "Server" 

ControlToValidate= "要 验证 的 控件 ID" 

ErrorMessage= "错误 信息 " 

ControlToCompare= "要 比较 的 控件 ID" 

Type= "String|Integer|Double|DateTime|Currency" 

Operator="Equal | NotEqual | GreaterThan | GreaterThanEqual | LessThan | LessThanEqual | 
DataTypeCheck" 


Display= "Static|Dymatic|None" 


be 
占 位 符 


< /ASP:CompareValidator> 
在 以 上 标准 代码 中 ,Type 表示 要 比较 的 控件 的 数据 类 型 ;Operator 表示 比较 操作 ， 
比较 有 7 种 方式 ;其 他 属性 和 RequiredFieldValidator 相同 。 在 这 里 ,要 注意 ControlTo- 


Validate 和 ControlToCompare 的 区 别 , 如 果 Operate 为 GreaterThan, 那 么 必须 使 Con- 
trolToCompare 大 于 ControlToValidate 才 是 合法 的 。 


3.RangeValidator 控件 
验证 输入 是 否 在 一 定 范围 ,范围 用 MaximumValue( 最 大 ) 和 MinimumValue( 最 小 ) 
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来 确定 ,标准 代码 如 下 : 


<ASP:RangeValidator id= "Validator ID”Runat= "Server"” 
ControlToValidate= "要 验证 的 控件 ID" 
TYpe= "Integer" 
MinimumValue= "最 小 值 " 
MaximumValue= "最 大 值 " 
ErrorMessage= "错误 信息 " 
Display- "Static1DymaticlNonen 
> 


占 位 符 


< /ASP:RangeValidator> 


在 以 上 代码 中 ,用 MinimumValue 和 MaximumValue 来 界定 控件 输入 值 的 范围 ,用 
type 来 定义 控件 输入 值 的 类 型 。 


4.RegularExpressionValidator 控件 
正则 表达 式 验 证 控件 的 功能 非常 强大 ,可 以 自己 很 容易 地 构造 验证 方式 。 下 面 来 看 
一 下 标准 代码 : 


<ASP:RegularExpressionValidator id= "Validator ID" Runat= "Server" 
ControlToValidate= "要 验证 控件 ID" 
ValidationExpression= "正则 表达 式 " 
ErrorMessage= "错误 信息 " 
Display= "Static" 
> 
占 位 符 
< /ASP:RegularExpressionValidator> 


在 以 上 标准 代码 中 , ValidationExpression 不 同 的 字符 表示 不 同 的 含义 :“. ”表示 任 
意 字 符 ;* * ”表示 和 其 他 表达 式 一 起 ,表示 任意 组 合 ;“[A-Z]” 表 示 任 意 大 写 字母 ;“\d” 表 
示 任 意 一 个 数字 。 

5.ValidationSummary 控件 


该 控件 收集 本 页 的 所 有 验证 错误 信息 ,并 可 以 将 它们 组 织 以 后 再 显示 出 来 。 其 标准 
代码 如 下 : 


<ASP:ValidationSummary id= "Validator ID" RunaT= "Server" 
HeaderText= " 头 信息 " 
ShowSummary= "True|False" 
DisplayMode= "List|BulletList|SingleParagraph" 

条 

< /ASP: ValidationSummary > 


在 以 上 标准 代码 中 ,HeaderText 相当 于 表 的 HeadText. DisplayMode 表示 错误 信息 
显示 方式 : List 相当 于 HTML 中 的 二 BR 过; BulletList 相当 于 HTML 中 的 二 LI 二 ; 
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SingleParagraph 表示 错误 信息 之 间 不 作 分 割 。 
6.CustomValidator 控件 
该 控件 用 自 定义 的 函数 界定 验证 方式 ,其 标准 代码 如 下 : 


<ASP:CustomValidator id="Validator ID”RunRt= "Server” 
ControlToValidate= "要 验证 的 控件 " 
OnserverValidateFunction= "验证 函数 " 
ErrorMessage= "错误 信息 " 
Display= "Static1DYymatic|None” 

> 

占 位 符 


< /ASP: CustomValidator> 


以 上 代码 中 ,用 户 必须 定义 一 个 函数 来 验证 输入 。 
3.3.4 导航 控件 


一 个 Web 站 点 ,尤其 是 信息 量 大 的 大 中 型 Web 站 点 ,应 为 用 户 提供 站 点 导航 。 在 网 
页 上 ,ASP.NET 2.0 提供 了 站 点 导航 的 一 种 简单 方法 ,即使 用 站 点 导航 控件 SiteMap- 
Path TreeView 和 Menu 来 完成 站 点 导航 。 

1. 页 面 导航 的 结构 


在 ASP. NET 2.0 中 ,要 实现 页 面 导 航 , 应 该 先 以 xml 的 形式 ,提供 出 整个 网 站 的 页 
面 结构 层次 。 可 以 编写 一 个 叫 web. sitemap 的 XML 文本 文件 .在 该 文件 中 定义 出 整个 
要 导航 页 面 的 结构 层次 。 如 程序 3-20 所 示 。 

程序 3-20 XML 文本 文件 (web. sitemap) 
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其 中 ,web. sitemap 文件 必须 包含 根 结 点 sitemap。 而 且 , 设 置 一 个 父 sitemapnode 结 
点 ,该 结 点 表明 是 默认 的 站 点 首页 。 在 该 父 sitemapnode 结 点 下 ,可 以 有 若干 个 子 
sitemapnode 结 点 ,分别 按 层次 结构 代表 了 网 站 的 各 子 栏目 (留意 一 下 上 例 中 ,各 个 子 结 
点 之 间 的 包含 关系 )。 而 每 一 个 sitemapnode 结 点 中 ,有 如 下 若干 个 属性 。 

。 URL 属性 : 该 属性 指出 要 导航 的 栏目 的 地 址 链接 ,在 web. sitemap 的 定义 中 , 必 
须 是 每 个 栏目 的 相对 地 址 。 

。 Title 属性 : 该 属性 指出 每 个 子 栏目 的 名 称 , 显 示 在 页 面 中 。 

。 Description 属性 : 该 属性 指定 时 ,用 户 将 鼠标 移动 到 该 栏目 时 ,出 现 有 关 该 栏目 
的 相关 提示 ,类 似 于 tooltips 属性 。 

在 设计 好 sitemap 属性 后 , 接 下 来 就 可 以 一 步 步 构 建 页 面 导航 功能 了 ,将 sitemap- 
datasource 控件 绑 定 到 如 sitemappath ,treeview 和 menu 等 控件 中 。 也 就 是 说 ,将 它们 的 
数据 源 设置 为 sitemapdatasource 控件 。 

2. TreeView 控件 


用 Treeview 控件 和 sitemapdatasource 控件 配合 使 用 的 方法 。TreeView 树 形 列表 
控件 十 分 适合 于 做 页 面 导航 。 下 面 例子 具体 说 明 如 何 使 用 TreeView 控件 。 具 体 步骤 如 
下 所 示 。 

(1) 新 建 一 个 网 站 ,添加 上 文 的 web. sitemap 文件 。 

(2) 添加 一 个 名 叫 Navigation 的 master 类 型 的 页 面 ,如 程序 3-21 所 示 。 

程序 3-21 导航 页 面 代 码 
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</asp:TreeView> 
</td> 
<tqd style= "width: 100px"> 
<asp:contentplaceholder id="ContentPlaceHolderl" runat="server"> 
< /asp:contentplaceholder> 
</td></tr> 
</table> 
<asp:SiteMapDataSource ID= "SiteMapDataSourcel" Runat= "server"/> 
</div> 
< /fom> 
< /body> 
</html> 


在 上 面 的 代码 中 ,TreeView 控件 的 Datasource 属性 中 ,就 指定 了 sitemapdatasource 


控件 ,并且 在 treeview 控件 中 ,也 定义 了 不 同 结 点 的 样式 。 在 完成 了 masterpage 页 面 后 ， 
就 等 于 已 经 把 网 站 的 模板 页 建立 起 来 了 。 


(3) 接 下 来 就 可 以 新 建 其 他 子 页 面 , 以 继承 masterpage 页 面 ,并 且 新 建 各 自 页 面 的 


内 容 了 。 新 建 一 个 default. aspx 页 面 , 如 程序 3-22 所 示 。 


程序 3-22 ”设计 首页 


<%@Page Language="C#" MasterPageFile= "Navigation.master" Title= "Default Page"%> 
<asp:Content ContentPlaceHolderID= "ContentPlaceHolderl"ID="Contentl" Runat="Server" 
> 

This is the default page 

< /asp:Content> 


可 以 看 到 , 当 建 立 了 模板 页 后 ,就 可 以 新 建 其 他 的 子 页 面 了 ,只 需要 在 其 中 的 Cont- 
entPlaceHolderID 中 写 入 不 同 的 内 容 就 可 以 了 。 运 行 起 来 后 ,如 图 3-24 所 示 。 


EL 
文件 四 ”编辑 EE) 查看 WD 收藏 和 ) 工具 GD) 帮助 00 


Ga 日- 四 加 | Pas 六 wmx @| 会 -对 


址 加 | 本 hp/hocdhostlode/metsiwunoodt :图 回回 swat 图 


主页 
江 鼻 认 帮 着 
编程 语言 


网 络 语言 ”这 是 首页 | 
人 区 类 坟 鹿 

历史 

教育 


图 3-24 使 用 TreeView 控件 的 效果 图 
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3. Menu 控件 


这 部 分 介绍 如 何 将 menu 菜单 控件 和 sitemapdatasource 控件 配合 使 用 。 其 中 ,在 上 
面 例 子 的 基础 上 ,在 二 table style 二 "width: 100%; height: 100%" border= 二 "1" 记 下 面 增 
加 程序 3-23 所 示 代 码 就 可 以 了 。 

程序 3-23 ”使 用 Menu 控件 的 代码 


<tr height= "100px"> 

<td colspan="2" align= "left"> 

<asp:Menu ID= "Menul” Runat="Server" DataSourceID="SiteMapDataSourcel"> 
</asp:Menu> 

</td> 

</tr> 


其 中 ,增加 了 一 个 menu 控件 ,将 其 datasourceid 属性 设 定 为 sitemapdatasourcel 就 
可 以 了 ,运行 结果 如 图 3-25 所 示 。 当 然 , 可 以 改变 menu 控件 的 显示 位 置 ,如 可 以 将 其 改 
成 垂直 样式 显示 。 


Default Page - Nicrosoft Internet Explorer 
文件 时 ”编辑 下 ) 查看 WD 收藏 WA) 工具 I) 和 帮助 op 


四 与- 昌 - 国 国 纹 时 闪 Wx 加仑 -和 


地 址 四) | 柄 Mtp://1ocuhost:1048/Websitel/Defadlt : 国 固 到 多 smert 图 邯 


主页 计算 机 书籍 
人 文 类 书籍 "历史 
教育 


主页 
坟 党 加 广 秘 


入 | http://localhost: 1048/WebSitel/Adnin/ 


图 3-25 ”使 用 Menu 控件 的 效果 图 


4. SiteMapPath 控件 

在 页 面 中 经 常见 到 的 显示 出 页 面 当 前 路 径 的 导航 条 功能 ,在 ASP. NET 2.0 中 也 可 
以 轻易 实现 ,可 以 使 用 其 中 的 sitemappath 控件 。 紧 接着 在 上 文 代码 中 的 menu 控件 下 ， 
增加 程序 3-24 所 示 代 码 就 可 以 了 。 

程序 3-24 ”使 用 SiteMapPath 控件 的 代码 


<tr height= "100px"> 
<td colspan= "2" align= "left"> 
Currently Selected Page is: 
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<asp:SiteMapPath Runat= "Server" ID=- "SiteMapPathl">< /asp:SiteMapPath> 
</td> 
</tr> 


要 注意 的 是 ,只 要 增加 sitemappath 控件 就 可 以 了 ,因为 它 会 自动 和 已 经 增加 的 
sitemapdatasource 控件 进行 绑 定 。 运 行 结果 如 图 3-26 所 示 。 


Default Page - 了 icrosoft Internet Explorer 园 回 加 


文件 E) 编辑 E) 查看 Q0。 收 疗 从) 工具 0 帮助 0 [3 
全 型 - 昌 : 国 国 给 万 岩 六 ta 天 | 全 - 避 辐 -站 


地 址 四 ) | 笑 http://1ocalhost:1048/Websitel/Defanlt ospx 圈 回 先 儿 snsert [sy 


A 


主页 


当前 选中 的 页 是 : 主页 


主页 
坟 草 而 方 散 
编程 语言 


回 


图 3-26 ”使 用 SiteMapPath 控件 的 效果 图 


3.3.5 用 户 控件 和 自 定义 控件 


ASP.NET 的 组 件 化 并 不 仅仅 局 限 在 使 用 工具 箱 中 的 服务 器 控件 , 它 还 支持 用 户 控 
件 和 自 定义 控件 ,从 而 进一步 增强 了 组 件 的 重用 和 代码 共享 功能 。 

1. 用 户 控件 

1) 用 户 控 件 的 基础 知识 

以 下 是 一 个 简单 的 用 户 控件 : 

<hl> Date:20050101< /hl> 

将 这 句 话 保存 在 以 . ascx 为 后 组 的 文件 中 ,就 成 为 用 户 控件 。 这 个 控件 非常 简单 ,但 
是 它 包 含 了 两 条 基本 原则 :用 户 控件 保存 在 以 . ascx 为 后 缀 的 文件 中 ;用 户 控件 中 没有 
二 html/ 二 一 head/ 二 一 boby/ 二 标记 。 

用 户 控件 也 可 以 包含 方法 、 属 性 和 事件 ,只 是 在 这 个 简单 的 例子 中 没有 表现 。 调 用 这 
个 用 户 控件 ,需要 使 用 @Register 指令 ,如 在 下 面 的 ASPX 文件 中 ,就 可 以 调用 这 个 用 户 
控件 ,如 程序 3-25 所 示 。 
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程序 3-25 调用 用 户 控件 


<%Q@Register TagPrefix= "Test”TagName= "Date" Src= "date-ascx"g> 
<html> 

<boby> 

<form> 

<Test:Date runat="server" jid= "Counterl"/> 

</form> 

< /boby> 

</htm> 


执行 这 个 文件 ,就 可 以 在 页 面 上 以 标题 一 的 格式 显示 Data: 20050101。 在 调用 中 ， 
一 Test: Date 二 标记 声明 了 这 个 用 户 控件 的 一 个 实例 。 二 外 @ Register TagPrefix = 
"Test” TagName 二 "Date”Src 二 "date. ascx" % 二 语句 ,告知 ASP. NET 在 解析 到 一 Test， 
Date 二 时 如 何 工 作 。 这 其 中 的 关键 就 是 在 页 面 顶部 的 这 个 注册 说 明 。 
要 注册 控件 , 先 要 定义 如 下 三 个 属性 。 
。 TagPrefix: 定义 控件 位 置 的 命名 空间 。 有 了 命名 空间 制约 ,就 可 以 在 同一 页 面 使 
用 不 同 功 能 的 同名 控件 。 
。 TagName: 指向 所 使 用 控件 的 名 字 。 在 同一 个 命名 空间 里 控件 名 是 唯一 的 。 控 
件 名 一 般 都 表明 控件 的 功能 。 
。 Src: 指向 控件 资源 文件 。 资 源 文件 使 用 虚拟 路 径 。 
控件 注册 之 后 ,就 可 以 像 其 他 服务 器 控件 一 样 被 使 用 。 通 过 定义 目标 前 级 和 目标 名 ， 
即 可 像 使 用 服务 器 端 内 建 控 件 一 样 地 进行 使 用 。 同 时 也 确定 了 使 用 服务 器 端 运行 方式 。 
下 面 是 页 面 调用 用 户 控件 的 基本 方式 : 


< TagPrefix:TagName runat= "server"/> 


TagPrefix: TagName 结合 生成 一 个 标签 , 当 服 务 器 解析 时 把 它 与 指定 的 用 户 控件 关 
联 在 一 起 ,这 个 结合 对 已 注册 的 每 个 用 户 控 件 必须 是 唯一 的 。 

最 简单 的 放置 用 户 控 件 的 方法 是 直接 从 资源 管理 器 中 拖 放 到 目的 页 面 上 。 系 统 会 自 
动 在 目的 页 面 上 添加 需要 添加 的 语句 。 

2) 将 Web 窗 体 页 转换 成 用 户 控件 

如 果 用 户 已 经 开发 了 Web 窗 体 页 ,并 决定 在 整个 应 用 程序 访问 其 功能 , 则 可 以 对 该 
文件 进行 一 些小 改动 .将 其 改 为 用 户 控 件 。Web 用 户 控件 与 Web 窗 体 也 非常 相似 ,它们 
是 使 用 相同 的 技术 创建 的 。 当 将 Web 窗 体 也 转换 为 Web 用 户 控 件 时 ,创建 一 个 可 再 次 
使 用 的 UI 组件, 用户 将 可 以 在 其 他 Web 窗 体 页 上 使 用 该 组 件 。 

从 Web 页 面 到 自 定义 控件 需要 修改 的 部 分 如 下 。 

(1) 删除 过 html/ 二 一 head/ 二 一 boby/ 二 标记 。 

(2) 把 二 %@ Page Language 一 "C 井 ”ClassName 一 " 关 关 关 关 关 "全 改 为 二 %@@ 
Control Language 一 "C 井 " ClassName 一 "< x* 关 关 <" 上 ,把 文件 存 为 . ascx 文件 即 可 。 

对 比 ASCX 文件 和 ASPX 文件 ,它们 的 异同 如 表 3-11 所 示 。 
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表 3-11 ASCX 文件 和 ASPX 文件 的 异同 点 


用 户 控 件 Web 页 面 
组 成 文件 一 个 .ascx 文件 和 一 个 . cs 文件 一 个 . aspx 文 件 和 一 个 . cs 文件 
编写 格式 以 <%@ Control 开头 ,其 中 没有 <html、 以 一 % @ Page 开头 ,其 中 包含 
< 一 form> 等 标签 <html> .一 form> 等 标签 
运行 方式 由 CLR 编译 ,然后 存在 高 速 缓存 中 相同 
能 否 独 立 运行 ”| 不 能 ,只 能 被 Web 页 调用 可 以 独立 运行 
2. 自 定义 控件 


用 户 自己 开发 自 定义 控件 并 非 一 件 很 困难 的 事 。 用 户 只 需 定义 一 个 直接 或 间接 从 
Control 派生 的 类 ,并 重 写 它 的 Render 方法 即 可 。System. Web. UI. Control 与 System. 
Web. UI. WEBControls. WebControl 两 个 类 服务 器 的 基 类 ,Control 类 定义 了 所 有 服务 器 
控件 共有 的 属性 ,方法 和 事件 ,其 中 包括 控制 控件 执行 生命 周期 的 方法 和 事件 ,以 及 ID、 
UniqueID、Parent、ViewState 和 Controls( 子 控件 集合 ) 等 属性 。Control 没有 用 户 界面 
(UD 特定 的 任何 功能 。 如 果 创 作 的 控件 没有 提供 UI, 或 者 组 合 了 其 他 呈现 其 自己 的 UI 
控件 , 则 从 Control 派生 。WebControl 类 是 从 Control 派生 的 ,并 为 UI 功能 提供 附加 的 
属性 和 方法 。 这 些 属性 包括 ForeColor、BackColor、Font、BorderStyle、Height 和 Width 。 
WebControl 是 ASP. NET 中 Web 服务 器 控件 系列 的 基 类 。 如 果 控 件 呈 现 UI, 则 从 
WebControl 派生 。 

用 户 可 以 重 写 从 基 类 继承 的 属性 ,方法 和 事件 ,并 可 以 将 新 的 属性 \ 方 法 和 事件 添加 
到 自 定 义 控件 中 。 如 前 所 述 , 可 以 使 用 重 写 Render 方法 来 实现 HTML 代码 的 输出 。 
Render 方法 采用 System. Web. UI. HtmlTextWriter 类 型 的 参数 ,控件 要 发 送 到 客户 端 
的 HTML 作为 字符 串 参数 传递 到 HtmlTextWriter 的 Write 方法 。 

3. 用 户 控件 和 自 定义 控件 的 异同 

对 用 户 控 件 和 自 定义 控件 而 言 ,用 户 控件 更 适合 创建 内 部 的 、 应 用 程序 特定 的 控件 ， 
而 自 定义 控件 则 更 适合 创建 通用 的 和 可 再 分 发 的 控件 。 具 体 来 讲 , 可 以 从 5 个 方面 说 明 
它们 的 异同 。 

(1) 当 在 两 个 控件 之 间 进 行 选择 时 ,部 署 是 最 重要 的 考虑 因素 。 自 定义 控件 采用 大 
多 数 应 用 程序 可 以 使 用 的 动态 链接 库 文 件 (. DLL ) 为 创建 可 在 分 发 的 组 件 而 设计 。 用 户 
控件 是 为 单个 应 用 程序 而 设计 的 ,用 户 控件 必须 以 源 代 码 存在 (. ascx 文件 ) ,这 种 需求 有 
增加 维护 成 本 的 副作用 。 

(2) 创建 自 定义 控件 的 技术 与 创建 用 户 控 件 技术 是 不 相同 的 , 自 定义 控件 是 用 . NET 
编程 语言 通过 编写 一 个 从 System. Web. UI. Control 类 中 直接 或 者 间接 派生 的 托管 类 而 
创建 ,但 并 没有 对 创建 自 定义 控件 提供 设计 器 支持 。 而 用 户 控件 类 间接 地 从 System. 
Web. UI. Control 派生 而 来 ,用 户 控 件 以 . ascx 文件 的 形式 声明 性 地 创建 ,类 似 于 设计 和 
开发 ASP. NET 页 面 的 方式 。 

(3) 由 于 创建 机 制 不 同 ,用 户 控件 和 自 定义 控件 提供 不 同 的 内 容 和 布局 方式 。 自 定 
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义 控件 非常 适用 于 通过 在 编程 方式 生成 的 布局 中 表现 动态 内 容 。 例 如 ,生成 一 个 具有 行 
的 数据 绑 定 控件 ,或 一 个 动态 结 点 的 控件 树 。 用 户 控件 的 布局 在 . ascx 文件 创建 时 声明 ， 
所 以 当 需 要 固定 布局 的 相对 静态 内 容 时 ,用 户 控件 是 最 好 的 选择 。 

(4) 目前 ,Visual Studio. NET 为 自 定义 控件 和 用 户 控件 提供 不 同 的 设计 期 能 力 。 
Visual Studio. Net 为 自 定 义 控件 提供 很 大 程度 的 设计 期 支持 功能 ,例如 ,可 以 支持 设计 
时 的 属性 ,方法 。Visual Studio. NET 对 用 户 控 件 只 有 很 少 的 实际 期 支持 。 用 户 控 件 并 
不 在 属性 窗口 中 显示 属性 和 事件 ,也 不 能 将 其 放 到 工具 箱 中 。 

(5) 虽然 自 定义 控件 和 用 户 控件 遵循 不 同 的 创建 模型 ,并 且 有 不 同 的 特性 ,但 这 两 个 
控件 都 是 从 相同 的 基 类 直接 或 间接 派生 的 。 用 户 控 件 在 页 面 中 第 一 次 使 用 时 ,将 作为 普 
通 的 服务 器 控件 被 解析 并 编译 进 配 件 中 。 此 后 用 户 控 件 的 行为 就 像 任 何其 他 的 编译 控件 
一 样 ,所 以 性 能 上 差别 不 是 很 大 。 


3.4 ASP.NET 基本 对 象 


3.4.1 Application 对 象 


Application 表示 的 是 应 用 程序 , 它 是 一 个 可 以 执行 的 单一 文件 ,用 来 完成 特定 的 功 
能 。 在 ASP. NET 中 Application 是 ASP. NET 的 一 个 特殊 的 内 置 对 象 , 它 代表 一 个 目录 
及 所 有 目录 中 的 ASP. NET 文件 ,对 于 文件 之 间 共 享 数据 是 十 分 方便 的 。 并 且 , 由 于 它 
是 个 内 置 对 象 , 不 需要 进行 任何 对 象 的 实例 化 ,就 可 以 直接 使 用 。 

Application 对 象 的 方法 和 属性 如 表 3-12 所 示 。 


表 3-12 ”Application 对 象 中 常见 方法 和 属性 


名 称 方法 /属性 说 明 
Lock 方法 锁定 Application 对 象 ,防止 其 他 用 户 访问 Application 对 象 
i 方法 ht Application 对 象 的 锁定 ,其 他 用 户 可 以 访问 Application 
onteats 扩容 属性 包含 所 有 不 使 用 OBJECT 之 标记 定义 的 ,已 经 为 会 话 建立 的 
所 有 项 目 
StaticObjects 集合 属性 人 
1. 声明 对 象 


应 用 程序 状态 存储 在 HttpApplication 类 的 实例 中 。 在 用 户 初次 访问 应 用 程序 中 的 
任何 URL 资源 时 ,将 会 创建 HttpApplicationState 实例 。HttpApplicationState 类 通常 
通过 HttpContext 类 的 Application 属性 访问 。 

可 以 在 Web 应 用 程序 的 Global. asax 文件 中 通过 二 object runat 王 "server" 二 声明 向 
StaticObjects 集合 添加 对 象 。 随 后 ,就 可 以 在 应 用 程序 中 的 任何 地 方 通过 代码 对 用 这 种 
方法 定义 的 应 用 程序 状态 进行 访问 。 


LI 
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< object runat= "server" scope= "application" ID= "WebInfo" PROGID= "MSWC.WEBINFO"> 
</object> 

上 面 的 示例 代码 声明 了 一 个 ID 为 WebInfo 的 Application 对 象 。 

2. 保存 Application 对 象 中 的 值 

可 以 通过 以 下 三 种 方法 保存 Application 对 象 中 的 值 。 

(1) 将 值 写 人 应 用 程序 状态 。 将 值 写 人 应 用 程序 状态 比较 简单 ,示例 如 下 : 


Application[Message]=" 欢 迎 您 。"; 


(2) 应 用 程序 启动 时 将 值 写 入 应 用 程序 状态 。 在 应 用 程序 global. asax 文件 的 Ap- 
plication_Start 处 理 程序 中 ,设置 应 用 程序 状态 变量 的 值 。 同 常规 的 . aspx 页 一 样 , Htt- 
pApplicationState 类 也 通过 Application 对 象 公 开 , 示 例如 下 : 

Application[Message]=" 欢 迎 您 。"; 

Application[PageReuestCount]=0; 

(3) 用 锁定 方法 将 值 写 入 应 用 程序 状态 。 应 用 程序 状态 变量 可 以 同时 被 多 个 线程 访 
问 。 因 此 ,为 了 防止 产生 无 效 数据 ,在 设置 值 前 ,必须 锁定 应 用 程序 状态 ,只 供 一 个 线程 写 
入 ,示例 如 下 : 


Application.Lock(); 
Application["PageReuestCount"]= ((int)Application["PageReuestCount"] )+1; 
Application.UnLock(); 


3. 从 应 用 程序 状态 中 读 取 值 

应 用 程序 状态 存储 类 型 化 为 Object 的 数据 。 因 此 ,即使 将 数据 存储 于 应 用 程序 状态 
中 时 不 必 对 其 进行 序列 化 ,也 必须 在 检查 数据 时 将 其 强制 转换 为 相应 的 类 型 。 尽 管 可 以 
强制 转换 null 对 象 ,但 是 如 果 尝 试 通过 某 些 其 他 方法 (如 检查 其 类 型 ) 使 用 不 存在 的 应 用 
程序 状态 项 ,就 会 引发 NullReferenceException 异常 。 

从 应 用 程序 状态 中 读 取 值 ,首先 确定 应 用 程序 变量 是 否 存在 ,然后 在 访问 该 变量 时 将 
其 转换 成 相应 的 类 型 ,示例 如 下 : 

if (Application["AppStartTime"]!=null) 

{ 

DateTime myAppStartTime= (DateTime)Application["AppstartTime"]; 
} 


3.4.2 Response 对 象 


Response 对 象 是 用 于 把 消息 向 页 面 上 输出 的 内 置 对 象 。 在 ASP. NET 的 环境 中 ,向 
页 面 输出 消息 的 方法 有 很 多 ,但 Response 对 象 并 不 只 有 一 个 Write 方法 , 它 可 以 提供 方 
法 和 属性 ,如 表 3-13 所 示 。 
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表 3-13 Response 对 象 常见 方法 和 属性 


名 称 方法 /属性 说 明 
AppHeader 方法 用 指定 的 值 给 页 面 添加 HTML 首 标 信息 
AppendToLog 方法 为 Web 服务 器 添加 日 志 信息 
BinaryWrite 方法 将 信息 不 经 过 字符 集 转换 ,直接 输出 到 页 面 上 
Clear 方法 清除 缓冲 区 内 容 
End 方法 停止 当前 ASP. NET 进程 的 执行 
Flush 方法 将 缓冲 中 的 内 容 输出 
Redirect 方法 将 浏览 器 重 定向 到 另 一 个 URL 
Write 方法 向 页 面 输出 字符 串 
WriteFile 方法 把 文件 的 内 容 向 页 面 输出 
Buffer 属性 确定 数据 发 送 给 客户 之 前 是 否 要 缓冲 
CacheControl 属性 是 否 要 用 高 速 缓存 输出 内 容 
CharSet 属性 字符 集 名 称 

指定 响应 的 HTTP 内 容 的 MIME 类 型 ,默认 值 是 text/html。 也 

yi 属性 。 | 可 以 用 image/gif 来 表示 GIF 图 形 
Expires 属性 高 速 缓存 过 期 之 前 的 时 间 
ExpiresAbsolute 属性 高 速 缓存 过 期 的 日 期 和 时 间 
IsClientConnected 属性 客户 端 是 否 和 服务 器 断 开 连 接 
PICS 属性 PICS 标签 
Status 属性 返回 服务 器 的 状态 
Cookies 属性 Cookie 集 

1. 重 定向 


在 网 页 编程 中 ,经 常会 遇 到 在 程序 执行 到 某 个 位 置 进 行 页 面 转调 的 情况 。 
Response. Redirect 方法 可 以 满足 这 种 需求 ,例如 执行 代码 Response. Redirect("http: // 
www. 163. com"); ,页 面 跳 转 到 网 易 163 的 主页 。 

2. 向 客户 端 发 送信 息 

使 用 write 方法 ,向 屏幕 输出 500 个 值 。 

for (int i=1;i<500;i++) 

{ 

Response.Write ("i="+i+"<BR>"); 

} 

3. 缓冲 HTML 


Buffer 属性 可 以 确定 数据 发 送 给 客户 之 前 是 否 要 缓冲 。 它 的 默认 值 是 True, 表 示 确 
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定数 据 发 送 给 客户 之 前 需要 缓冲 ,也 就 是 说 把 需要 发 送 给 客户 的 信息 先 放置 到 一 个 预先 
设 定 的 缓冲 区 中 ,然后 再 一 次 性 地 发 送 给 客户 。 如 果 把 这 个 值 设 置 为 False, 那 么 所 有 的 
信息 都 会 在 产生 的 时 候 立 即 发 送 给 客户 。 从 速度 上 说 ,这 种 不 使 用 缓冲 的 方法 会 比 使 用 
缓冲 的 方法 要 慢 得 多 。 


3.4.3 Request 对 象 


Request 对 象 是 用 于 提取 浏览 器 中 用 户 输入 信息 的 内 置 对 象 。 在 使 用 这 个 内 部 对 象 
时 ,用户 的 信息 可 以 通过 表单 来 提供 ,也 可 以 通过 直接 用 URL 的 参数 来 提供 ,还 可 以 通 
过 环境 变量 来 提供 。Request 对 象 的 几 个 常用 属性 和 方法 如 表 3-14 所 示 。 


表 3-14 Request 对 象 常用 方法 和 属性 


名 称 


方法 /属性 


说 明 


TotalBytes 


属性 


只 读 属性 , 它 表明 用 户 提交 的 数据 的 字 节 总 数 


ClientCertication 集合 是 客户 认证 信息 集合 。 如 果 客 户 正在 使 


emai 属性 。 | 用 安全 认证 ,那么 从 这 里 可 以 得 到 相关 的 认证 信息 

人 属性 Cookies 集合 。 如 果 使 用 了 Cookie, 那 么 将 从 这 个 集合 中 读 到 
相关 的 Cookie 信息 

oa 属性 Form 集合 。 在 发 出 请 求 的 页 面 中 ,所 有 表单 中 的 控件 信息 都 
可 以 从 Form 集合 中 得 到 

QueryString 属性 QueryString 集合 。 通 过 页 面 的 URL 可 以 得 到 相关 参数 的 值 。 
这 些 值 可 以 自动 解析 并 使 用 

SEE 属性 ServerVariables 集合 。 通 过 ServerVariables 可 以 得 到 相关 的 环 
境 变量 。 通 过 获得 环境 变量 的 值 ,可 以 搜集 很 多 浏览 器 信息 

ApplicationPath 属性 被 请 求 页 面 的 目录 信息 

Path 属性 被 请 求 页 面 的 完整 路 径 ( 包 括 文件 名 ) 

PhysicalApplication 属性 被 请 求 页 面 在 硬盘 上 的 物理 路 径 名 称 

Browser 属性 检索 用 户 浏览 器 信息 

Url 属性 返回 浏览 器 提交 的 完整 的 URL 地 址 

RawUrl 属性 返回 浏览 器 提交 的 没有 协议 和 域名 的 URL 

RequestType 属性 请 求 Post 还 是 Get 

UserHostName 属性 用 户 的 机 器 名 

UserHostAddress 属性 用 户 机 器 的 IP 地址 

UserLanguages 属性 用 户 浏览 器 配置 的 语言 

IsSecureConnection 属性 HTTP 连接 是 否 使 用 加 密 

BinaryRead 方法 得 到 用 户 上 传 的 文件 数 总 和 

MapPath 方法 将 当前 请 求 的 URL 中 的 虚拟 路 径 映 射 到 服务 器 上 的 物理 路 径 
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1. 获取 QueryString 值 

在 程序 中 ,经 常 使 用 从 一 个 页 面 传递 来 的 字符 串 参数 。 例 如 ,在 页 面 1 中 创建 一 个 连 
接 , 指 向 页 面 2, 并 用 QueryString 来 查询 两 个 变量 。 

<a href= "page2.aspx?ID-= 65Name=Wang"> 查 看 < /a> 

在 页 面 2 中 接收 到 从 页 面 1 传送 过 来 的 两 个 变量 ,如 下 : 

<Script Language= "C# "Runat= "Server"> 


void Page Load (object sender,System.EventArgs e) 

{ 
Response.Write ("变量 ID 的 值 : "+Request .Querystring["ID"]+"<br>"); 
Response.Write ("变量 Name 的 值 : "+ Request .QuerSstring["Name"]); 

} 

</Script> 


运行 上 面 的 代码 ,结果 如 下 : 

变量 ID 的 值 : 6 

变量 Name 的 值 : Wang 

上 面 的 例子 可 以 得 到 QueryString 的 值 。 

用 类 似 的 方法 ,可 以 获得 Form、Cookies 和 ServerVariables 的 值 。 调 用 方法 都 是 ， 

Request .Collection["Variable"] 

不 过 ,为 了 优化 程序 的 执行 效率 ,建议 最 好 还 是 使 用 Collection, 因 为 过 多 的 搜索 会 降 
低 程序 的 执行 效率 。 

2. 获取 文件 的 物理 路 径 

通过 Request 对 象 可 以 获取 文件 的 物理 路 径 , 代 码 如 下 : 


Request .MapPath ("FileName"); 
可 以 通过 这 条 语句 来 得 到 某 个 文件 的 实际 物理 位 置 .这 个 方法 常常 用 在 需要 使 用 实 
际 路 径 的 地 方 。 


3.4.4 Server 对 象 


Server 对 象 的 属性 反映 了 Web 服务 器 的 各 种 信息 , 它 提供 了 服务 器 可 以 提供 的 各 种 
服务 。 这 个 对 象 不 负责 为 用 户 存储 什么 信息 ,也 没有 什么 事件 。 

Server 对 象 常用 的 方法 和 属性 如 表 3-15 所 示 。 

1. 返回 服务 器 计算 机 名 称 

通过 Server 对 象 的 MachineName 属性 来 获取 服务 器 计算 机 的 名 称 , 示 例如 下 : 
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表 3-15 Server 对 象 常用 的 方法 和 属性 


名 称 方法 /属性 说 明 
MachineName 属性 机 器 名 
ScriptTimeout 属性 说 明 页 面 在 超时 之 前 可 以 运行 多 长 时 间 
CreatObject 方法 创建 一 个 对 象 
Execute 方法 用 于 执行 一 个 子 例 程 或 存储 过 程 
GetLastError 方法 检索 最 后 一 次 发 生 的 错误 
HtmlDecode 方法 对 已 被 编码 的 HTML 字符 串 进行 解码 
HtmlEncode 方法 用 于 把 所 有 的 标记 字符 转换 成 等 价 的 没有 功能 的 字符 
MapPath 方法 得 到 一 个 文件 的 目录 路 径 
Transfer 方法 把 原来 页 面 的 内 置 对 象 的 值 和 对 象 的 状态 传递 给 新 的 页 面 
URLEncode 方法 把 URL 中 所 有 的 特殊 字符 转化 成 对 应 的 非 功 能 等 价 内 容 


<Script Language= "C# "Runat= "Server"> 


void Page_Load (object sender, System.EventRrgs e) 


{ 


String ThisMachine; 


ThisMachine= Server. MachineName; 


Response.Write (ThisMachine); 


} 


</script> 


2. 设置 客户 端 请 求 的 超时 期 限 


用 法 如 下 : 


Server.ScriptTimeout= 60; 


本 例 中 ,将 客户 端 请 求 超时 期 限 设置 为 60s, 如 果 60s 内 没有 任何 操作 ,服务 器 将 断 开 
与 客户 的 连接 。 


3. 利用 HtmlEncode 和 HtmlDecode 方法 对 网 页 内 容 编码 


当 想 在 网 页 上 显示 HTML 标签 时 , 若 在 网 页 中 直接 输出 则 会 被 浏览 器 解 译 为 HT- 
ML 的 内 容 , 所 以 要 通过 Server 对 象 的 HtmlEncode 方法 将 它 编码 再 输出 。 如 要 将 编码 
后 的 结果 编码 回 原本 的 内 容 , 则 使 用 HtmlDecode 方法 。 下 列 程序 代码 范例 使 用 Htm- 
1Encode 方 法 将 “<B 二 HTML 内 容 二 /B 二 ”编码 后 输出 至 浏览 器 .再 利用 HtmlDecode 
方法 把 编码 后 的 结果 编码 还 原 。 


<Script Language= "C#" Runat= "Server"> 
void Page_Load (object sender, System.EventArgs e) 


对 
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String strHtmlContent; 
strHtmlContent= Server-HtmlEncode ("<B>HTML 内 容 < /B> "); 
Response.Write (strHtmlContent); 
Response.Write ("<p>"); 
strHtmlContent= Server.HtmlDecode ("strHtmlContent"); 
Response.Write (strHtmlContent); 

} 

</script> 


运行 上 述 示例 ,通过 输出 结果 可 以 发 现 ,编码 后 的 HTML 标注 变 成 了 &lt;B&gt; 
HTML 内 容 ;&lt;/B&gt; ,这 是 因为 二 B 二 编程 了 &lt;B&gt;, 一 /B 二 编程 了 &lt;/ 
B&gt; ,所 以 才能 在 页 面 中 显示 HTML 标注 。 

4. 建立 虚拟 路 径 与 服务 器 物理 目录 间 了 映射 

使 用 MapPath 方法 可 以 将 指定 相对 或 虚拟 路 径 映 射 到 服务 器 上 相应 的 物理 目录 上 。 
语法 如 下 : 

public string MapPath (string path); 

参数 Path 表示 指定 映射 物理 目录 或 虚拟 目录 路 径 。 若 Path 以 一 个 正 斜 杠 (/) 或 反 
斜 杜 人 \) 开 始 , 则 MapPath 方法 返回 路 径 将 Path 视 为 完整 的 虚拟 路 径 。 若 Path 不 是 以 
斜 杠 开始 , 则 MapPath 方法 返回 同 页 面 文件 中 已 有 的 路 径 相 对 的 路 径 。 这 里 需要 注意 的 
是 ,MapPath 方法 不 检查 返回 的 路 径 是 否 正确 或 在 服务 器 上 是 否 存 在 。 

对 于 下 列 示例 ,文件 data. txt 和 包含 下 列 脚 本 的 test. aspx 文件 都 位 于 目录 c:\Inet- 
pub\wwwroot\aspx 下 。c:\Inetpub\wwwroot 目录 被 设置 为 服务 器 的 宿主 目录 。 下 列 
示例 使 用 服务 器 变量 PATH_INFO 映射 当前 文件 的 物理 路 径 。 以 下 脚本 : 

Server .MapPath (Request .ServerVariables ("PATH INFO")); 

输出 : 

C:\interpub\wwwroot\aspx\test .aspx 


由 于 下 列 示 例 中 的 路 径 参数 不 是 以 斜 杠 字符 开始 的 ,所 以 它们 被 相对 映射 到 当前 目 
录 , 此 处 是 目录 c:\Inter\wwwroot\aspx。 以 下 脚本 : 


Server .MapPath (data.txt); 
Server .MapPath (aspx\data.txt); 


输出 : 


C:\interpub\wwwroot\aspx\data.txt 
C:\interpub\wwwroot\aspx\aspx\data.txt 


3.4.5 Session 对象 


Session 对 象 是 HttpSessionState 的 一 个 实例 。 该 类 为 当前 用 户 会 话 提供 信息 ,还 提 
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供 对 可 用 于 存储 信息 的 会 话 范围 的 缓存 访问 ,以 及 控制 如 何 管理 会 话 的 方法 。 
Session 对 象 常用 的 方法 和 属性 如 表 3-16 所 示 。 


表 3-16 Session 对 象 常用 的 方法 和 属性 


名 称 方法 /属性 说 明 
Count 属性 获取 会 话 状态 集合 中 Session 对 象 的 个 数 
ae 属性 获取 并 设置 在 会 话 状 态 提供 程序 终止 会 话 之 前 ,各 请 求 之 间 人 允许 的 超 
时 期 限 
SessionID 属性 获取 用 于 标识 会 话 的 唯一 会 话 ID 
Add 方法 新 增 一 个 Session 
Clear 方法 清除 会 话 状态 中 的 所 有 值 
Remove 方法 删除 会 话 状态 集合 中 的 项 
RemoveAll 方法 消除 所 有 会 话 状态 值 


1. 获取 Session 对 象 的 个 数 
Count 属性 可 以 帮助 统计 正在 使 用 的 Session 对 象 的 个 数 ,语句 非常 简单 ,示例 如 下 


Respose.Write (Session.Count); 


2. 通过 Add 方法 设置 Session 对 象 

通过 Add 方法 可 以 设置 Session 对 象 的 值 ,语法 如 下 : 
Session.add(" 变 量 名 ", 变 量 值 ); 

在 具体 应 用 中 ,可 以 这 样 使 用 : 


int userId=1; 


string userName= "test"; 


string userPwd= "admin"; 


Session.Add ("userId", userId); 


Session.Add ("userName", userName); 

Session.Add ("userPwd", userPwd); 

在 上 面 的 例子 中 创建 了 userld、userName 和 userPwd 三 个 Session 来 存储 用 户 的 登 
录 信息 。 程 序 随时 都 可 以 通过 这 三 个 Session 对 象 来 查看 用 户 的 连接 状态 ,这 是 实际 的 
项 目 中 最 常见 的 Session 应 用 。 

需要 注意 的 是 ,也 可 以 不 使 用 Add 方法 来 设置 Session 对 象 ,语法 如 下 : 

Session[" 变 量 名 "]= 变 量 值 ; 


这 样 ,上 面 的 例子 就 可 以 改 为 : 


Session["userId"]=userId; 


Session["userName"]=userName; 
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Session["userPwd"]=userPwd; 


需要 指出 的 是 ,以 上 两 种 语句 在 作用 上 是 相同 的 ,可 以 根据 自己 的 习惯 来 使 用 。 
3.4.6 ”Cookie 对 象 


Cookie 是 一 小 段 文本 信息 .伴随 着 用 户 请 求 和 页 面 在 Web 服务 器 和 浏览 器 之 间 传 
递 。 用 户 每 次 访问 站 点 时 , Web 应 用 程序 都 可 以 读 取 Cookie 包含 的 信息 。Cookie 跟 
Session、Application 类 似 , 也 是 用 来 保存 相关 信息 。 但 Cookie 和 其 他 对 象 的 最 大 不 同 
是 ,Cookie 将 信息 保存 在 客户 端 ,而 Session 和 Application 是 保存 在 服务 器 端 。 也 就 是 
说 ,无 论 何 时 用 户 连接 到 服务 器 , Web 站 点 都 可 以 访问 Cookie 信息 。 这 样 , 既 方便 用 户 
的 使 用 ,也 方便 了 网 站 对 用 户 的 管理 。 

Cookie 对 象 常用 的 方法 和 属性 如 表 3-17 所 示 。 


表 3-17 Cookie 对象 常 用 的 方法 和 属性 


名 称 方法 /属性 说 明 

Name 属性 获取 或 设置 Cookie 的 名 称 

Value 属性 获取 或 设置 Cookie 的 Value 

Expires 属性 获取 或 设置 Cookie 的 过 期 日 期 和 时 间 

Version 属性 获取 或 设置 此 Cookie 符合 的 HTTP 状态 维护 版 本 
Add 方法 新 增 一 个 Cookie 变量 

Clear 方法 清除 Cookie 集合 内 的 变量 

Get 方法 通过 变量 名 或 索引 得 到 Cookie 的 变量 值 

GetKey 方法 以 索引 来 获取 Cookie 的 变量 名 称 

Remove 方法 通过 Cookie 变量 名 来 删除 Cookie 变量 

1. 设置 Cookie 

下 面 的 示例 将 创建 名 为 LastVisit 的 新 Cookie, 将 该 Cookie 的 值 设 置 为 当前 日 期 和 


时 间 , 并 将 其 添加 到 当前 Cookie 集合 中 ,所 有 Cookie 均 通 过 HTTP 输出 流 在 Set-Cookie 
头 中 发 送 到 客户 端 。 


HttpCookie MYyCookie= new HttpCookie ("LastVisit"); 
DateTime now= DateTime.Now; 
MyCookie.Value=now.ToString (); 
MyCookie.Expires=now.AddHours (1); 
Response.Cookie.Add (MyCookie); 


运行 上 面 的 例子 ,将 会 在 用 户 机 器 的 Cookies 目录 建立 如 下 内 容 的 文本 文件 。 


Mycookie 
LastVisit 
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尽管 上 面 的 这 个 例子 很 简单 ,但 可 以 从 中 扩展 许多 富有 创造 性 的 应 用 程序 。 

2. 获取 客户 端 发 送 的 Cookie 信息 

下 面 的 示例 是 依次 通过 客户 端的 所 有 Cookie, 并 将 每 个 Cookie 的 名 称 、 过 期 日 期 安 
全 参数 和 值 发 送 到 HTTP 输出 ,如 程序 3-26 所 示 。 

程序 3-26 ”获取 客户 端 发 送 的 Cookie 信息 


int loopl, loop2; 
HttpCookieCollection MyCookieColl; 
HttpCookie MyCookie; 
MyCookieColl= Request .Cookies; 

// 把 所 有 的 cookie 名 放 到 一 个 字符 数组 中 
String[] arrl=MyCookieColl .AllKeys; 

// 用 cookie 名 获取 单个 cookie 对 象 

for (loopl= 0;loopl<arrl.Length;loopl++) 


{ 


MyCookie=MyCookieColl [arrl [loopl1]]; 
Response.Write ("Cookie:"+ MyCookie.Name+ "<br>"); 
Response.Write ("Expires:"+ MyCookie. Expires+ "<br>"); 
Response.Write ("Secure:"+MyCookie. Secure+ "<br>"); 
// 将 单个 cookie 的 值 放 人 一 个 对 象 数组 
String [] arr=MyCookie.Values>allKeys; 
// 遍 历 cookie 值 集合 打印 所 有 值 
for (loop2= 0;lo0p2< arr2.Length;Loop2++) 


{ 


Respones.Write ("Value"+ loop2+ ":"+arr2[loop2]+ "<br>"); 


} 
} 


3.4.7 ”Cache 对 象 


对 于 每 个 应 用 程序 域 均 创建 该 类 的 一 个 示例 ,并 且 只 要 对 应 的 应 用 程序 域 保持 活动 ， 
该 示例 保持 有 效 。 有 关 此 类 示例 的 信息 通过 HttpContext 对 象 的 Cache 属性 或 Page 对 
象 的 Cache 属性 来 提供 。 
Cache 对 象 常 用 的 方法 和 属性 如 表 3-18 所 示 。 


表 3-18 Cache 对象 常 用 的 方法 和 属性 


名 方法 /属性 说 明 
5 属性 获取 存储 在 缓存 中 的 项 数 。 当 监视 应 用 程序 性 能 或 使 用 ASP. NET 
跟踪 功能 时 ,此 属性 可 能 非常 有 用 
Item 属性 获取 或 设置 指定 键 外 的 缓存 项 
Add 方法 将 指定 项 添加 到 Cache 对 象 
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续 表 
名 方法 /属性 说 明 
Get 方法 从 Cache 对 象 检索 指定 项 
Remove 方法 从 应 用 程序 的 Cache 对 象 移 除 指定 项 
rt 方法 向 Cache 对 象 插入 项 。 使 用 此 方法 的 某 一 个 版 本 改写 具有 相同 key 


参数 的 现 有 Cache 项 


1. 检索 为 ASP. NET 文本 框 服务 器 控件 缓存 的 值 

Get 方法 可 以 从 Cache 对 象 检索 指定 项 ,其 唯一 的 参数 key 表示 要 检索 的 缓存 项 的 
标识 符 。 该 方法 返回 检索 到 的 缓存 项 ,未 找到 该 键 时 为 空 引用 。 

下 面 的 示例 展示 如 何 检索 为 ASP. NET 文本 框 服务 器 控件 缓存 的 值 。 


Cache.Get ("MyTextBox.Value"); 


2. 移 除 Cache 对 象 
Remove 方法 可 以 Cache 对 象 移 除 指 定 项 ,其 唯一 的 参数 key 表示 要 移 除 的 缓存 项 
的 String 标识 符 ,该 方法 返回 Cache 移 除 项 。 如 果 未 找到 键 参数 中 的 值 , 则 返回 空 引用 。 
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现在 的 网 站 一 般 都 是 动态 页 面 ,支持 用 户 交互 ,代码 与 数据 库 分 离 。 很 多 网 站 一 般 都 
是 数据 库 服务 器 和 Web 服务 器 分 离 。 故 我 们 构建 网 站 时 离 不 开 与 数据 库 的 交互 。 在 
.NET 中 ,与 数据 库 的 交互 是 通过 ADO. NET 来 实现 的 。 

ADO. NET 是 对 Microsoft ActiveX Data Objects (ADO) 一 个 跨 时 代 的 改进 , 它 提供 
了 平台 互 用 性 和 可 伸缩 的 数据 访问 。 由 于 传送 的 数据 都 是 XML 格式 的 ,因此 任何 能 够 
读 取 XML 格式 的 应 用 程序 都 可 以 进行 数据 处 理 。 事 实 上 ,接受 数据 的 组 件 不 一 定 是 
ADO. NET 组 件 , 它 可 以 是 基于 一 个 Microsoft Visual Studio 的 解决 方案 ,也 可 以 是 任何 
运行 在 其 他 平台 上 的 应 用 程序 。 

ADO. NET 是 一 组 用 于 和 数据 源 进 行 交互 的 面向 对 象 类 库 。 通 常情 况 下 ,数据 源 是 
数据 库 , 但 它 同 样 也 能 够 是 文本 文件 .Excel 表格 或 者 XML 文件 。 因 为 本 章 的 需要 ,我 们 
将 ADO. NET 当 作 是 一 种 与 数据 库 的 交互 方式 。 

ADO. NET 允许 和 不 同类 型 的 数据 源 及 数据 库 进行 交互 ,然而 并 没有 与 此 相关 的 一 
系列 类 来 完成 这 样 的 工作 。 因 为 不 同 的 数据 源 采 用 不 同 的 协议 ,所 以 对 于 不 同 的 数据 源 
必须 采用 相应 的 协议 。 一 些 老式 的 数据 源 使 用 ODBC 协议 ,许多 新 的 数据 源 使 用 OleDb 
协议 ,并 且 现在 还 在 不 断 出 现 更 多 的 数据 源 , 这 些 数据 源 都 可 以 通过 . NET 的 ADO 
.NET 类 库 来 进行 连接 。 

ADO. NET 提供 与 数据 源 进行 交互 的 相关 的 公共 方法 ,但 是 对 于 不 同 的 数据 源 采用 
一 组 不 同 的 类 库 。 这 些 类 库 称 为 Data Providers, 并 且 通 常 是 以 与 之 交互 的 协议 和 数据 源 


的 类 型 来 命名 的 。 
ADO. NET 是 与 数据 源 交互 的 . NET 技术 。 有 许多 的 Data Providers, 它 将 允许 与 
不 同 的 数据 源 交流 取决 于 它们 所 使 用 的 协议 或 者 数据 库 。 然 而 无 论 使 用 什么 样 的 


Data Provider, 将 使 用 相似 的 对 象 与 数据 源 进行 交互 。SqlConnection 对 象 管理 与 数据 源 
的 连接 。SqlCommand 对 象 允许 与 数据 源 交流 并 发 送 命令 给 它 。 为 了 进行 快速 的 只 “向 
前 ”地 读 取 数据 ,使 用 SqlDataReader。 如 果 想 使 用 断 开 数 据 , 使 用 DataSet 并 实现 能 进行 
读 取 或 者 写 和 人 数据 源 的 SqlDataAdapter。 
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4.1 数据 库 基础 


4.1.1 数据 库 定义 和 分 类 


1. 数据 库 定义 

数据 库 是 一 个 以 某 种 有 组 织 的 方式 存储 的 数据 集合 。 为 了 使 一 个 数据 库 可 以 真正 具 
有 功能 性 , 它 不 仅 要 储存 大 量 的 记录 良好 ,更 要 进入 容易 。 此 外 ,新 的 信息 和 变化 ,也 应 该 
是 相当 容易 的 投入 。 为 了 有 一 个 高 效 的 数据 库 系统 ,需要 把 这 种 程式 管理 的 质疑 和 资料 
储存 于 系统 。 这 通常 被 人 们 称 为 数据 库 管理 系统 。 

2. 数据 库 的 分 类 

数据 库 中 的 数据 是 有 结构 的 ,这 些 结构 反映 了 事物 之 间 的 联系 ,对 这 种 结构 的 描述 就 
是 数据 模型 ,是 表示 数据 与 数据 之 间 联 系 的 方法 。 不 同 的 数据 模型 以 不 同 的 方式 把 数据 
组 织 到 数据 库 中 ,常用 的 数据 模型 有 三 种 : 层次 模型 关系 模型 和 网 络 模 型 。 

1) 层次 模型 数据 库 

层次 模型 以 树 形 结构 表示 实体 (记录 ) 与 实体 之 间 的 联系 。 层 次 模型 像 一 棵 倒置 的 
树 , 根 结 点 在 上 ,层次 最 高 , 子 结 点 在 下 , 逐 层 排 列 。 

层次 模型 的 特点 : 有 且 仅 有 一 个 结 点 无 父 结 点 ,这 个 结 点 即 为 树 的 根 ;其 他 结 点 有 且 
仅 有 一 个 结 点 。 

2) 网 络 模型 

网 络 模型 是 以 网 状 表示 实体 与 实体 之 问 的 联系 。 网 状 模型 可 以 表示 多 个 从 属 关系 的 
联系 ,也 可 以 表示 数据 间 的 交叉 关系 , 即 数据 间 的 横向 关系 与 纵向 关系 , 它 是 层次 模型 的 
扩展 


网 状 模 型 的 特点 : 可 以 有 一 个 以 上 的 结 点 无 父 结 点 ;至 少 有 一 个 子 结 点 有 一 个 以 上 
的 父 结 点 ;在 两 个 结 点 之 间 有 两 个 或 两 个 以 上 的 联系 。 

3) 关系 模型 

关系 模型 是 目前 最 流行 的 类 型 的 数据 库 和 一 个 极其 有 力 的 工具 。 关 系 模型 是 把 数据 
结构 看 成 一 个 二 维 表 , 每 个 二 维 表 就 是 一 个 关系 ,关系 模型 是 由 若干 个 二 维 表格 组 成 的 集 
合 , 是 以 关系 数学 理论 为 基础 的 。 在 关系 模型 中 ,操作 的 对 象 和 结果 都 是 二 维 表 , 这 种 二 

在 二 维 表 中 ,每 一 行 称 为 一 个 记录 ,用 于 表示 一 组 数据 项 ; 表 中 的 每 一 列 称 为 一 个 字 
段 或 属性 ,用 于 表示 每 一 列 中 的 数据 项 ; 表 中 的 第 一 行 称 为 字段 名 ,用 于 表示 每 个 字段 的 
名 称 。 

关系 模型 的 特点 : 表格 中 的 每 一 列 都 是 不 可 再 分 的 基本 属性 ;每 一 列 都 被 指定 一 个 
不 相同 的 名 字 ; 各 行 不 允许 重复 ; 行 、 列 的 次 序 无 关 。 

关系 型 数据 库 的 使 用 程序 界面 是 所 谓 的 SQL 或 标准 查询 语言 。SQL 是 目前 所 采用 
的 几乎 所 有 的 关系 型 数据 库 。 关 系数 据 库 产品 是 非常 容易 定制 的 ,以 适应 几乎 任何 类 型 
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的 数据 存储 。 
4.1.2 SQL Server 数据 库 简介 


美国 Microsoft 公司 推出 的 一 种 关系 型 数据 库 系统 。SQL Server 是 一 个 可 扩展 的 、 
高 性 能 的 ,为 分 布 式 客户 机 /服务 器 计算 所 设计 的 数据 库 管理 系统 ,实现 了 与 Windows 
NT 的 有 机 结合 ,提供 了 基于 事务 的 企业 级 信息 管理 系统 方案 。 其 主要 特点 如 下 。 

。 高 性 能 设计 ,可 充分 利用 Windows NT 的 优势 。 

。 系统 管理 先进 ,支持 Windows 图 形 化 管理 工具 ,支持 本 地 和 远程 的 系统 管理 和 
配置 。 
强壮 的 事务 处 理 功 能 ,采用 各 种 方法 保证 数据 的 完整 性 。 
支持 对 称 多 处 理 器 结构 ,存储 过 程 和 ODBC, 并 具有 自主 的 SQL 语言 。 SQL Serv- 
er 以 其 内 置 的 数据 复制 功能 、 强 大 的 管理 工具 、 与 Internet 的 紧密 集成 和 开放 的 
系统 结构 ,为 广大 的 用 户 、 开 发 人 员 和 系统 集成 商 提供 了 一 个 出 众 的 数据 库 平 台 。 

本 章 的 研究 主要 是 基于 SQL Server 数据 库 。 

1. 数据 库 的 主 码 (主键 ) 

能 够 唯一 表示 数据 表 中 每 个 记录 的 “字段 ?或 者 “字段 "的 组 合 就 称 为 主 码 。 

2. 数据 库 表 

数据 表 是 数据 库 中 一 个 非常 重要 的 对 象 ,是 其 他 对 象 的 基础 。 没 有 数据 表 , 关 键 字 、 
主键 和 索引 等 也 就 无 从 谈 起 。 在 数据 库 画 板 中 可 以 显示 数据 库 中 的 所 有 数据 表 ( 即 使 不 
是 用 PowerBuilder 创建 的 表 ) 、 创 建 数 据 表 和 修改 表 的 定义 等 。 

关系 数据 库 通常 包含 多 个 表 。 数 据 库 实际 上 是 表 的 集合 ,数据 库 的 数据 或 者 信息 都 
是 存储 在 表 中 的 。 表 是 对 数据 进行 存储 和 操作 的 一 种 逻辑 结构 ,每 一 个 表 都 代表 一 个 对 
用 户 意 义 的 对 象 。 例 如 ,一 个 公司 数据 库 中 ,有 雇员 表 、 部 门 表 、 库 存 表 、 销 售 表 和 工资 表 
等 。 我 们 经 常见 到 的 成 绩 表 就 是 一 种 表 , 它 是 由 行 和 列 组 成 的 ,并 且 可 以 通过 名 字 来 识别 
数据 。 列 包含 了 列 的 名 字 ,数据 类 型 及 列 的 其 他 属性 ; 行 包 含 了 列 的 记录 或 者 数据 。 下 面 
给 出 一 个 成 绩 单 ,如 表 4-1 所 示 , 其 中 姓名 ,语文 ,数学 和 英语 都 是 列 , 而 行 包 含 了 这 个 表 
的 数据 , 即 每 个 人 的 各 科 成 绩 。 


表 4-1 成 绩 单 
姓 名 语 文 数 学 英语 
王 小 童 78 100 87 
张 柳 风 85 92 95 
紫 云 飞 65 89 86 
黄 天 龙 98 67 75 


3. 数据 操作 语言 
DML(Data Manipulation Language, 数 据 操作 语言 ) 用 于 检索 或 者 修改 数据 。DML 


第 4 章 ”数据库 基 础 与 ADO.NET 


组 可 以 细 分 为 以 下 几 个 语句 。 

。 SELECT: 用 于 检索 数据 。 

。 INSERT: 用 于 增加 数据 到 数据 库 。 

。 UPDATE: 用 于 从 数据 库 中 修改 现存 的 数据 。 

。 DELETE: 用 于 从 数据 库 中 删除 数据 。 

4. 数据 检索 

在 SQL 中 SELECT 语句 通常 用 于 检索 数据 库 ,或 者 检索 满足 设 定 条 件 的 数据 ,以 下 
是 简单 的 SELECT 语句 的 格式 : 


select "column1l" [,"column2",etc] from "tablename" [where "condition"]; 
[]=optional 


其 中 列 的 名 字 跟 着 SELECT 关键 字 , 它 决定 了 哪 一 列 将 被 作为 结果 返回 。 可 以 任意 
指定 多 个 列 ,或 者 可 以 使 用 * * ”来 选择 所 有 的 列 。 

表 的 名 字 是 紧 跟 着 FROM 关键 字 的 , 它 指出 了 哪个 表格 将 作为 最 后 结果 被 查询 。 而 
WHERE 子 句 (可 选 ) 指 出 哪个 数据 或 者 行将 被 返回 或 者 显示 , 它 是 根据 关键 字 WHERE 
后 面 描述 的 条 件 而 来 的 。 

在 WHERE 子 句 中 可 以 有 以 下 的 条 件 选择 : = (等 于 )、 二 (大 于 )、 二 (小 于 )、 二 = 
(大 于 等 于 ) .二 =( 小 于 等 于 ) 和 二 二 ( 不 等 于 )。LIKE 参见 以 下 注释 。 

注释 : LIKE 模式 匹配 操作 符 同样 可 以 使 用 在 WHERE 子 句 的 条 件 中 。LIKE 是 一 
个 功能 强大 的 操作 符 , 它 可 以 选择 “喜欢 ”指定 的 行 。“%”* 可 以 被 用 来 匹配 任何 可 能 的 字 
符 , 它 可 以 出 现在 指定 字符 的 前 面 或 者 后 面 .例如 : 


select first, last, city from empinfo where first LIKE 'Er$% "7 


以 上 这 条 SQL 语句 将 会 匹配 任何 名 字 以 Er 开始 的 名 字 , 这 里 必须 使 用 单 引号 。 或 
者 也 可 以 使 用 % 在 字符 的 前 面 .例如 : 


select first, last from empinfo where last LIKE '% s'; 


这 条 SQL 语句 将 会 匹配 任何 名 字 以 s 结尾 的 名 字 。 这 个 % 的 作用 就 跟 DOS 命令 的 
“* ”号 很 相似 。 


Select * from empinfo where first= "Eric'; 


以 上 的 SQL 语句 只 选择 first 名 字 为 Eric 的 行 。 
5. 插入 数据 到 表 
Insert 语句 用 于 往 表格 中 插入 或 者 增加 一 行 数据 , 它 的 格式 为 : 


insert into "tablename" (first colurm,***, last colum)values (first value,**,last value); 
[=optional 
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简单 举 个 例子 : 


这 里 要 注意 ,每 一 个 字符 串 都 要 用 单 引号 括 起 来 。 

为 了 往 表 中 插入 数据 ,要 在 关键 字 insert into 之 后 紧 跟 着 表 名 ,然后 是 左 圆 括号 , 接 
着 是 以 逗号 分 开 的 一 系列 的 列 名 ,再 是 一 个 右 圆 括号 ,然后 在 关键 字 values 之 后 跟着 一 
系列 用 圆 括号 括 起 的 数值 。 这 些 数值 是 要 往 表格 中 填 和 人 的 数据 ,它们 必须 与 指定 的 列 名 
相 匹配 。 字 符 串 必须 用 单 引 号 括 起 来 ,而 数字 不 用 。 在 上 面 的 例子 中 ,"Luke' 必 须 与 列 
first 相 匹配 ,而 45 必须 与 列 age 相 匹配 。 

假如 想 往 employee 表格 中 插入 以 下 数据 : 


Zhang Weiguo,28, 北 京 601 信箱 ,北京 
那么 要 使 用 以 下 的 SQL 语句 : 


6. 删除 记录 
Delete 语句 是 用 来 从 表 中 删除 记录 或 者 行 .其 语句 格式 为 : 


下 面 还 是 举 个 例子 : 


这 条 语句 没有 where 语句 ,所 以 它 将 删除 所 有 的 记录 ,因此 如 果 没 有 使 用 where 的 
时 候 ,要 千 万 小 心 。 如 果 只 要 删除 其 中 一 行 或 者 几 行 ,可 以 参考 以 下 的 语句 : 


这 条 语句 是 从 employee 表 中 删除 lastname 为 'May' 的 行 。 


这 条 语句 是 从 employee 表 中 删除 firstname 为 'Mike 或 者 'Eric' 的 行 。 为 了 从 表 中 删 
除 一 个 完整 的 记录 或 者 行 ,就 直接 在 "delete from" 后 面 加 上 表 的 名 字 , 并 且 利 用 where 指 
明 符合 什么 条 件 的 行 要 删除 即 可 。 如 果 没有 使 用 where 子 句 ,那么 表 中 的 所 有 记录 或 者 
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行将 被 删除 。 

7. 更 新 记录 

Update 语句 用 于 更 新 或 者 改变 匹配 指定 条 件 的 记录 , 它 是 通过 构造 一 个 where 语句 
来 实现 的 。 其 语句 格式 如 下 : 


Update "tablename" set "columname"= "newvalue" [, "nextcolumn"= "newvalue2"…] 
where "columnname"”OPERRTOR "value" [andlor "column”OPERRTOR "value"]; 
[]=optional 


下 面 举 个 例子 来 说 明 : 
update phone book set area_code= 623 where prefix=979; 
以 上 语句 是 在 phone_book 表 中 ,在 prefix==979 的 行 中 将 area_code 设置 为 623。 


update phone_ book set last name= 'Smith', prefix= 555, suffix= 9292 where last name= 
'Jones'; 


而 以 上 的 这 段 语句 是 在 phone_book 中 ,在 last_name 王 Jones 的 行 中 将 last_name 设 
置 为 Smith', prefix 为 555，suffix 为 9292 。 


update employee set age=age+ 1 where first name= 'Mary' and last name= 'Williams'; 


这 段 语句 是 在 employee 表 中 ,在 first_name 二 "Mary' 和 last_name 二 "Williams' 的 行 中 
将 age 加 1。 

8. 存储 过 程 

SQL 语句 执行 时 要 先 编译 ,然后 执行 。 存 储 过 程 就 是 编译 好 了 的 一 些 SQL 语句 。 
应 用 程序 需要 用 的 时 候 直 接 调 用 就 可 以 了 ,所 以 效率 很 高 。 

存储 过 程 是 由 流 控制 和 SQL 语句 书写 的 过 程 ,这 个 过 程 经 编译 和 优化 后 存储 在 数据 
库 服务 器 中 ,应 用 程序 使 用 时 只 要 调用 即 可 。 在 Oracle 中 ,若干 个 有 联系 的 过 程 可 以 组 
合 在 一 起 构成 程序 包 。 

使 用 存储 过 程 有 以 下 的 优点 。 

(1) 存储 过 程 的 能 力 大 大 增强 了 SQL 语言 的 功能 和 灵活 性 。 存 储 过 程 可 以 用 流 控 
制 语句 编写 ,有 很 强 的 灵活 性 ,可 以 完成 复杂 的 判断 和 较 复 杂 的 运算 。 

(2) 可 保证 数据 的 安全 性 和 完整 性 。 

(3) 通过 存储 过 程 可 以 使 没有 权限 的 用 户 在 控制 之 下 间接 地 存 取 数据 库 , 从 而 保证 
数据 的 安全 。 

(4) 通过 存储 过 程 可 以 使 相关 的 动作 在 一 起 发 生 , 从 而 可 以 维护 数据 库 的 完整 性 。 

(5) 在 运行 存储 过 程 前 ,数据 库 已 对 其 进行 了 语法 和 句法 分 析 , 并 给 出 了 优化 执行 方 
案 。 这 种 已 经 编译 好 的 过 程 可 极 大 地 改善 SQL 语句 的 性 能 。 由 于 执行 SQL 语句 的 大 部 
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分 工作 已 经 完成 ,所 以 存储 过 程 能 以 极 快 的 速度 执行 。 

(6) 可 以 降低 网 络 的 通信 量 。 

(7) 将 体现 企业 规则 的 运算 程序 放 和 人 数据库 服务 器 中 ,以 便 : 

OO 集中 控制 。 

@ 当 企业 规则 发 生变 化 时 在 服务 器 中 改变 存储 过 程 即 可 ,无 须 修改 任何 应 用 程序 。 
企业 规则 的 特点 是 要 经 常 变化 .如果 把 体现 企业 规则 的 运算 程序 放 入 应 用 程序 中 , 则 当 企 
业 规 则 发 生变 化 时 ,需要 修改 应 用 程序 的 工作 量 非常 大 (修改 、 发 行 和 安装 应 用 程序 )。 如 
果 把 体现 企业 规则 的 运算 放 入 存储 过 程 中 , 则 当 企业 规则 发 生变 化 时 ,只 要 修改 存储 过 程 
就 可 以 了 ,应 用 程序 无 须 任 何 变化 。 

数据 库存 储 过 程 的 实质 就 是 部 署 在 数据 库 端的 一 组 定义 代码 及 SQL。 


4.2 ADO.NET 模型 简介 


ADO. NET 提供 对 Microsoft SQL Server 等 数据 源 及 通过 OLE DB 和 XML 公开 的 
数据 源 的 一 致 访问 。 数 据 共享 使 用 者 应 用 程序 可 以 使 用 ADO. NET 来 连接 到 这 些 数据 
源 ,并 检索 .操作 和 更 新 数据 。 

ADO. NET 有 效 地 从 数据 操作 中 将 数据 访问 分 解 为 多 个 可 以 单独 使 用 或 一 前 一 后 
使 用 的 不 连续 组 件 。ADO. NET 包含 用 于 连接 到 数据 库 、 执 行 命令 和 检索 结果 的 . NET 
Framework 数据 提供 程序 。 可 以 直接 处 理 检索 到 的 结果 ,或 将 其 放 入 ADO. NET Data- 
Set 对 象 ,以 便 与 来 自 多 个 源 的 数据 或 在 层 之 间 进 行 远程 处 理 的 数据 组 合 在 一 起 ,以 特殊 
方式 向 用 户 公 开 。ADO. NET DataSet 对 象 也 可 以 独立 于 . NET Framework 数据 提供 程 
序 使 用 ,以 管理 应 用 程序 本 地 的 数据 或 源 自 XML 的 数据 。 

ADO. NET 类 在 System. Data. dll 中 ,并 且 与 System. Xml. dll 中 的 XML 类 集成 。 
当 编 译 使 用 System. Data 命名 空间 的 代码 时 ,引用 System. Data. dll 和 System. Xml. dll。 

以 前 ,数据 处 理 主要 依赖 于 基于 连接 的 双 层 模型 。 当 数据 处 理 越 来 越 多 地 使 用 多 层 
结构 时 ,程序 员 正 在 向 断 开 方式 转换 ,以 便 为 他 们 的 应 用 程序 提供 更 佳 的 可 缩放 性 。 

1. XML 和 ADO. NET 

ADO. NET 借用 XML 的 力量 来 提供 对 数据 的 断 开 式 访问 。ADO. NET 的 设计 与 
.NET Framework 中 XML 类 的 设计 是 并 进 的 ,它们 都 是 同一 个 结构 的 组 件 。ADO. 
NET 和 .NET Framework 中 的 XML 类 集中 于 DataSet 对 象 。 无 论 DataSet 是 文件 还 是 
XML 流 , 它 都 可 以 使 用 来 自 XML 源 的 数据 来 进行 填充 。 无 论 DataSet 中 数据 的 数据 源 
是 什么 ,DataSet 都 可 以 写 为 符合 万 维 网 联合 会 的 XML,DataSet 包含 了 XML Schema 语 
言 (XML Schema Definition, XSD) 架构 。 由 于 DataSet 固有 的 序列 化 格式 为 XML , 它 是 
在 层 间 移动 数据 的 优良 媒介 ,这 使 DataSet 成 为 以 远程 方式 向 XML Web Services 发 送 
数据 和 架构 上 下 文 ,以 及 从 XML Web Services 接收 数据 和 架构 上 下 文 的 最 佳 选择 。 
DataSet 也 可 与 XmlDataDocument 进行 同步 ,以 实时 地 提供 对 数据 的 关系 和 分 层 访问 。 

2. ADO. NET 组 件 

设计 ADO. NET 组 件 是 为 了 从 数据 操作 中 分 解 出 数据 访问 。ADO. NET 的 两 个 核 
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心 组 件 会 完成 此 任务 : DataSet 和 . NET Framework 数据 提供 程序 ,后 者 是 一 组 包括 
Connection、Command、DataReader 和 DataAdapter 对 象 在 内 的 组 件 。 

ADO. NET DataSet 是 ADO. NET 的 断 开 式 结构 的 核心 组 件 。DataSet 的 设计 目的 
很 明确 : 实现 独立 于 任何 数据 源 的 数据 访问 。 因 此 , 它 可 以 用 于 多 种 不 同 的 数据 源 ,用 于 
XML 数据 ,或 用 于 管理 应 用 程序 本 地 的 数据 。DataSet 包含 一 个 或 多 个 DataTable 对 象 
的 集合 ,这 些 对 象 由 数据 行 和 数据 列 ,以 及 主键 、 外 键 \、 约 束 和 有 关 DataTable 对 象 中 数据 
的 关系 信息 组 成 。 

ADO. NET 结构 的 另 一 个 核心 元 素 是 . NET Framework 数据 提供 程序 ,其 组 件 的 设 
计 目 的 相当 明确 : 实现 数据 操作 和 对 数据 的 快速 .只 进 、 只 读 访 问 ,Connection 对 象 提供 
与 数据 源 的 连接 。Command 对 象 使 用 户 能 够 访问 用 于 返回 数据 ,修改 数据 、 运 行 存储 过 
程 ,以 及 发 送 或 检索 参数 信息 的 数据 库 命令 。DataReader 从 数据 源 中 提供 高 性 能 的 数据 
流 。 最 后 , DataAdapter 提供 连接 DataSet 对 象 和 数据 源 的 桥梁 。DataAdapter 使 用 
Command 对 象 在 数据 源 中 执行 SQL 命令 ,以 便 将 数据 加 载 到 DataSet 中 ,并 使 对 Data- 
Set 中 数据 的 更 改 与 数据 源 保持 一 致 。 可 以 为 任何 数据 源 编写 . NET Framework 数据 提 
供 程 序 。 

.NET Framework 提供 了 4 个. NET Framework 数据 提供 程序 : SQL Server . NET 
Framework 数据 提供 程序 、OLE DB . NET Framework 数据 提供 程序 .ODBC . NET 
Framework 数据 提供 程序 和 Oracle .NET Framework 数据 提供 程序 。 为 了 使 应 用 程序 
获得 最 佳 性 能 ,应 该 使 用 适合 的 数据 源 的 . NET 数据 提供 程序 。 

例如 ,如 果 要 访问 SQL Server 2000 数据 库 , 则 应 该 使 用 SQL Server . NET Frame- 
work 数据 提供 程序 。 而 如 果 是 要 访问 Access 数据 库 , 则 应 该 使 用 OLE DB . NET 
Framework 数据 提供 程序 。 

图 4-1 阐释 了 ADO.NET 组 件 的 结构 模型 。 


DataAdapter 

区 要 
DataRowCollection 

[se 


DataColumnCollection 
UpdateCommand 

ConstraintCollection 
DeleteCommand 


DataRelationCollection 


所 


数据 库 
图 4-1 ADO. NET 组 件 结构 模型 


DataSet 的 设计 使 用 户 能 够 使 用 XML Web Services 方便 地 通过 Web 将 数据 传输 到 
客户 端 ,并 允许 使 用 . NET 远程 处 理 服务 在 . NET 组 件 之 间 传 送 数 据 。 还 可 以 通过 这 种 
方式 对 强 类 型 的 DataSet 进行 远程 处 理 。DataTable 对 象 也 可 以 与 远程 处 理 服务 一 起 使 
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用 ,但 不 能 通过 XML Web Services 进行 传输 。 

3. ADO. NET 平台 要 求 

支持 Microsoft. NET Framework SDK (包括 ADO. NET) 的 平台 包括 Microsoft 
Windows 2000、Windows NT 4( 带 Service Pack 6a) 、Windows Millennium Edition、Win- 
dows 98 和 Windows SE。 使 用 SQL Server. NET Framework 数据 提供 程序 或 OLE DB 
.NET Framework 数据 提供 程序 要 求 安装 Microsoft 数据 访问 组 件 2. 6 版 或 更 高 版 本 。 

以 下 代码 示例 显示 如 何 将 System. Data 命名 空间 包含 在 用 户 的 应 用 程序 中 ,以 使 用 
ADO.NET。 


[C#] 
using System.Data; 


ADO. NET 类 在 System. Data. dll 中 ,并 且 与 System. Xml. dll 中 的 XML 类 集成 。 
当 编 译 使 用 System. Data 命名 空间 的 代码 时 ,引用 System. Data. dll 和 System. Xml. dll。 


4.3 ADO.NET 组 件 


Connection、Command、DataReader 和 DataAdapter 对 象 是 . NET Framework 数据 
提供 程序 模型 的 核心 元 素 。 表 4-2 将 描述 这 些 对 象 。 
表 4-2 数据 提供 程序 模型 的 核心 元 素 


对 象 说 有 明 
Connection 建立 与 特定 数据 源 的 连接 
Command 对 数据 源 执行 命令 
DataReader 从 数据 源 中 读 取 只 进 且 只 读 的 数据 流 
DataAdapter 用 数据 源 填 充 DataSet 并 解析 更 新 


4.3.1 数据 连接 


1. 使 用 ADO. NET 连接 到 数据 源 

在 数据 访问 中 首先 必须 建立 到 数据 库 的 物理 连接 。 在 ADO. NET 中 ,可 以 使 用 
Connection 对 象 标识 与 一 个 数据 库 的 物理 连接 ,但 实际 上 ADO. NET 中 并 没有 一 个 名 字 
为 Connection 的 类 用 来 创建 Connection 对 象 。 事实 上 .每 个 数据 提供 程序 都 包含 自己 特 
有 的 Connection 对 象 。 若 要 连接 到 Microsoft SQL Server 7. 0 版 或 更 高 版 本 .应 该 使 用 
SQL Server . NET Framework 数据 提供 程序 的 SqlConnection 对 象 。 若 要 使 用 用 于 
SQL Server 的 OLE DB 提供 程序 (SQLOLEDB) 连 接 到 OLE DB 数据 源 或 者 连接 到 Mi- 
crosoft SQL Server 6. x 版 或 较 早 版 本 ,要 使 用 OLE DB . NET Framework 数据 提供 程序 
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的 OleDbConnection 对 象 。 若 要 连接 到 ODBC 数据 源 . 则 使 用 ODBC . NET Framework 
数据 提供 程序 的 OdbcConnection 对 象 。 若 要 连接 到 Oracle 数据 源 , 则 使 用 Oracle 
.NET Framework 数据 提供 程序 的 OracleConnection 对 象 。 

2. 使 用 ADO. NET 连接 SQL Server 数据 源 

SQL Server . NET Framework 数据 提供 程序 使 用 SqlConnection 对 象 提供 与 Mi- 
crosoft SQL Server 7. 0 版 或 更 高 版 本 的 连接 。 其 中 SqlConnection 对 象 是 在 System 
. Data. SqlClient 命名 空间 中 定义 的 , 它 包含 在 System. Data. DLL 程序 集中 。 使 用 Visu- 
al Studio. NET 开发 应 用 程序 时 ,一 般 项 目 都 自动 引用 了 该 程序 集 。 可 以 使 用 如 下 两 种 
方式 来 使 用 SqlConnection 类 。 


[C#] 
System.Data.SqlClient. SqlConnection conn=new System.Data.SqlClient. SqlConnection()， 


下 面 是 在 类 中 导入 了 这 个 命名 空间 后 的 使 用 方式 。 


[Cc#] 
using System.Data.SqlClient; 
SqlConnection conn=new SqlConnection(); 


显然 ,实际 编码 时 采用 后 一 种 方式 会 减少 代码 编写 量 。 

1) SqlConnection 类 

为 了 连接 SQL Server, 必 须 实例 化 SqlConnection 对 象 ,并 调用 此 对 象 的 Open 方法 。 
当 不 再 需要 连接 时 ,应 该 调用 这 个 对 象 的 Close() 方 法 关闭 连接 。SqlConnection 类 定义 
了 两 个 构造 函数 ,一 个 不 带 参 数 , 另 外 一 个 接受 连接 字符 串 。 因 此 可 以 使 用 下 面 两 种 方式 
的 任何 一 种 实例 化 连接 。 

SqlConnection conn=new SqlConnection(); 


conn.ConnectionString=ConnectionStringy 
conn.Open () 7 


或 者 : 


SqlConnection conn=new SqlConnection (ConnectionString) 7? 
conn.Open () > 


显然 ,使 用 后 一 种 方法 输入 的 代码 要 少 一 点 ,但 是 两 种 方法 执行 的 效率 并 没有 什么 不 
同 。 另 外 ,如 果 需 要 重用 Connection 对 象 去 使 用 不 同 的 身份 连接 不 同 的 数据 库 时 ,使 用 
第 一 种 方法 则 非常 有 效 。 例 如 : 


SqlConnection conn=new SqlConnection (); 
conn.Connectionstring=Connectionstringl; 
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conn.Open () 7 
// 访 问 数据 库 , 做 一 些 事情 


conn.Close () 7 


conn.ConnectionString= ConnectionString27 
conn.Open () 7 
// 访 问 数据 库 , 做 另外 一 些 事情 


conn.Close ()7 


但 是 必须 注意 ,只 要 当 一 个 连接 关闭 以 后 才能 把 另外 一 个 不 同 的 连接 字符 串 赋 值 给 
Connection 对 象 。 如 果 不 知 道 Connection 对 象 在 某 个 时 候 是 打开 还 是 关闭 ,可 以 检查 
Connection 对 象 的 State 属性 , 它 的 值 可 以 是 Open, 也 可 以 是 Closed, 这 样 就 可 以 知道 连 
接 是 否 是 打开 的 。 

2) SQL Server 的 连接 字符 串 

SQL Server .NET Framework 数据 提供 程序 支持 类 似 于 OLE DB(ADO) 连 接 字符 
串 格式 的 连接 字符 串 格式 。 连 接 字 符 串 包含 一 个 由 一 些 * 属 性 名 / 值 ? 对 组 成 的 集合 。 每 
一 个 “属性 名 / 值 ? 对 都 有 分 号 隔 开 。 如 : 


PropertyNamel=Valuel; PropertyName2=Value2;… ;PropertyNameN= ValueN; 


以 下 代码 示例 演示 如 何 创建 和 打开 与 SQL Server( 版 本 7. 0 或 更 高 版 本 ) 数 据 库 的 
连接 。 


[Cc#] 

using System.Data.SqlClient; 

SqlConnection conn=new SqlConnection(); 

conn.ConnectionString= "server= (local); Initial Catalog=northwind; User Id= sa; Password 
=admin"); 

conn.Open (); 


其 中 ,server 为 服务 器 地 址 ,其 值 (local) 表 示 使 用 本 地 机 器 ,另外 可 以 使 用 计算 机 名 
作为 服务 器 的 值 。Initial Catalog 属性 指明 了 连接 使 用 的 数据 库 , 上 面 的 连接 字符 串 表明 
使 用 数据 库 northwind。User Id 和 Password 则 分 别 指明 了 访问 数据 库 时 使 用 的 用 户 名 
和 密码 。 

3) SqlConnection 的 方法 

SqlConnection 对 象 有 自己 的 方法 ,如 前 面 已 经 使 用 过 的 Open 方法 和 Close 方法 。 
表 4-3 列 出 了 其 常用 的 方法 。 

数据 库 连 接 是 很 有 价值 的 资源 ,因为 连接 要 使 用 到 宝贵 的 系统 资源 ,如 内 存 和 网 络 带 
宽 , 因 此 对 数据 库 的 连接 必须 小 心 使 用 ,要 在 最 晚 的 时 候 建立 连接 (调用 Open 方法 ) ,在 
最 早 的 时 候 关 闭 连接 (调用 Close 方 法) 。 也 就 是 说 ,在 开发 应 用 程序 时 .不 再 需要 数据 连 
接 时 应 该 立刻 关闭 数据 。 
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表 4-3 SqlConnection 对 象 的 方法 


方法 名 称 方法 描述 
Open 使 用 ConnectionString 所 指定 的 属性 设置 打开 数据 库 连接 
Close 关闭 与 数据 库 的 连接 ,这 是 关闭 任何 打开 连接 的 首选 方法 
CreateCommand 创建 并 返回 一 个 与 SqlConnection 关联 的 SqlCommand 对 象 
ChangeDatabase 为 打开 的 SqlConnection 更 改 当前 数据 库 


3. 集成 安全 性 和 ASP. NET 

SQL Server 集成 安全 性 (也 称 为 受信 任 的 连接 ) 在 连接 到 SQL Server 时 可 以 提供 保 
护 , 因 为 它 不 会 在 连接 字符 串 中 公开 用 户 标识 和 密码 。 建 议 使 用 该 方法 对 连接 进行 身份 
验证 。 集 成 安全 性 使 用 正在 执行 的 进程 的 当前 安全 标识 或 标记 。 对 于 桌面 应 用 程序 , 安 
全 标识 或 标记 通常 是 当前 登录 的 用 户 的 标识 。ASP. NET 应 用 程序 的 安全 标识 可 设置 为 
几 个 不 同 的 选项 之 一 。 

下 面 的 示例 创建 一 个 SqlCommand 和 一 个 SqlConnection ,SqlCommand 将 在 下 面 介 
绍 。SqlConnection 打开 ,并 设置 为 SqlCommand 的 Connection。 然 后 ,该 示例 调用 Exe- 
cuteNonQuery 并 关闭 该 连接 。 为 了 完成 此 任务 ,将 为 ExecuteNonQuery 传递 一 个 连接 


字符 串 和 一 个 查询 字符 串 ,后 者 是 一 个 TransactrSQL INSERT 语句 。 
[Cc#] 
public void InsertRow (string myConnectionString) 
{ 


// 如 果 myConnectionstring 为 空 , 则 赋 一 个 默认 值 
if (myConnectionstring=="") 
{ 
myConnectionstring="Initial Catalog= Northwind; Data Source= localhost; Integrated 
Security= SSPI;"; 
} 
SqlConnection myConnection=new SqlConnection (myConnectionstring); 
string myInsertQuery=" INSERT INTO Customers (CustomerID, CompanyName) Values 
("NWIND', 'Northwind Traders')";» 
SqlCommand myCommand= new SqlCommand (myInsertQuery); 
myCommand.Connection=myConnection; 
myConnection.Open(); 
myCommand .ExecuteNonQuery (); 
myCommand.Connection.Close () 7 
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4.3.2 数据 命令 


1. 执行 命令 

当 建 立 了 数据 连接 之 后 .就 可 以 执行 数据 访问 和 数据 操纵 了 。 一 般 对 数据 库 的 操作 
被 概括 为 CRUD(Create、Read、Update 和 Delete) 。 可 以 使 用 Command 构造 函数 来 创建 
命令 ,该 构造 函数 采用 在 数据 源 、Connection 对 象 和 Transaction 对 象 中 执行 的 SQL 语句 
的 可 选 参数 。 也 可 以 使 用 Connection 的 CreateCommand 方法 来 创建 用 于 特定 Connec- 
tion 对 象 的 命令 。 可 以 使 用 CommandText 属性 来 查询 和 修改 Command 对 象 的 SQL 语 
句 。Command 对 象 公开 了 几 个 可 用 于 执行 所 需 操作 的 Execute 方法 。 当 以 数据 流 的 形 
式 返 回 结果 时 ,使 用 ExecuteReader 可 返回 DataReader 对 象 。 使 用 ExecuteScalar 可 返 
回 单个 值 ,使 用 ExecuteNonQuery 可 执行 不 返回 行 的 命令 。 

当 将 Command 对 象 用 于 存储 过 程 时 ,可 以 将 Command 对 象 的 CommandType 属性 
设置 为 StoredProcedure。 当 CommandType 为 StoredProcedure 时 ,可 以 使 用 Command 
的 Parameters 属性 来 访问 输入 及 输出 参数 和 返回 值 。 无 论调 用 哪 一 个 Execute 方法 ,都 
可 以 访问 Parameters 属性 。 但 是 , 当 调用 ExecuteReader 时 ,在 DataReader 关闭 之 前 ,将 
无 法 访问 返回 值 和 输出 参数 。 

以 下 代码 示例 演示 如 何 设置 Command 对 象 的 格式 ,以 便 从 Northwind 数据 库 中 返 
回 Categories 的 列表 。 


[Cc#] 

string commandText= "SELECT CategoryID, CategoryName FROM Categories"; 

SqlConnection conn=new SqlConnection ()? 

conn.ConnectionString= "server= (local); Initial Catalog=northwind; User Id= sa; Password 
=admin"); 

SqlCommand cmd= new SqlCommand (commandText, conn); 


或 者 : 


SqlConnection conn=new SqlConnection(); 

conn.ConnectionString= "server= (local); Initial Catalog=northwind; User Id= sa; Password 
=admin"); 

SqlCommand catCMD=new SqlCommand ("SELECT CategoryID, CategoryName FROM Categories", 


conn); 


2. 将 存储 过 程 用 于 命令 

存储 过 程 提供 了 数据 驱动 应 用 程序 中 的 许多 优点 。 利 用 存储 过 程 .数据 库 操作 可 以 
封装 在 单个 命令 中 ,为 获取 最 佳 性 能 而 进行 优化 并 通过 附加 的 安全 性 得 到 增强 。 虽 然 可 
以 通过 以 SQL 语句 的 形式 传递 参数 自 变量 之 前 的 存储 过 程 名 称 来 调用 存储 过 程 ,但 如 果 
使 用 ADO. NET Command 对 象 的 Parameters 集合 , 则 可 以 显 式 地 定义 存储 过 程 参 数 并 
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访问 输出 参数 和 返回 值 。 

若 要 调用 存储 过 程 , 则 将 Command 对 象 的 CommandType 设置 为 StoredProcedure。 
CommandType 一 旦 设置 为 StoredProcedure, 就 可 以 使 用 Parameters 集合 来 定义 参数 ， 
如 以 下 示例 所 示 。 

注释 : LIKE 模式 匹配 操作 符 同样 可 以 使 用 在 WHERE 子 句 的 条 件 中 。LIKE 是 一 
个 功能 强大 的 操作 符 , 它 可 以 让 用 户 选 择 “ 喜 欢 ” 指 定 的 行 。.% 可 以 被 用 来 匹配 任何 可 能 的 
字符 , 它 可 以 出 现在 指定 字符 的 前 面 或 者 后 面 。 

注意 : OdbcCommand 要 求 在 调用 存储 过 程 时 提供 完整 的 ODBC CALL 语法 。 


[Cc#] 

SqlConnection nwindConn= new SqlConnection("Data Source= localhost; Integrated Security= 
SSPI;Initial Catalog=northwind"); 

SqlCommand salesCMD= new SqlCommand ("SalesByCategory", nwindConn); 
salesCMD.CommandType= CommandType.StoredProcedure; 

SqlParameter myParm= salesCMD.Parameters.Add("@ CategoryName", SqlDbType.NVarChar, 15); 
myParm.Value= "Beverages"; 

nwindConn.Open () 7 

SqlDataReader myReader= salesCMD.ExecuteReader (); 

Console.WriteLine("{0}, {1}", myReader.GetName (0) ，myReader.GetName (1)); 

while (myReader.Read()) 

Console.WriteLine("{0}, $ {1}", myReader.GetString (0), myReader .GetDecimal (1)); 
} 
myReader.Close(); 


nwindConn.Close (); 


Parameter 对 象 可 以 使 用 Parameter 构造 函数 来 创建 ,或 通过 调用 Command 的 Pa- 
rameters 集合 的 Add 方法 来 创建 。Parameters. Add 会 将 构造 函数 参数 或 现 有 Parame- 
ter 对 象 用 作 输 入 。 在 将 Parameter 的 Value 设置 为 空 引用 时 ,使 用 DBNull. Value。 

对 于 Input 参数 之 外 的 参数 ,必须 设置 ParameterDirection 属性 来 指定 参数 类 型 是 
Input、Output 还 是 ReturnValue。 以 下 示例 显示 创建 Input、Output 和 ReturnValue 参 
数 之 间 的 差异 。 


[C# ] 

SqlCommand sampleCMD=new SqlCommand ("SampleProc", nwindConn); 
sampleCMD.CommandType= CommandType.StoredProcedure; 

SqlParameter sampParm= sampleCMD. Parameters.Add ("RETURN VALUE", SqlDbType.Int); 
sampParm.Direction= ParameterDirection.ReturnValue; 

sampParm= sampleCMD. Parameters.Add ("@ InputParm", SqlDbType.NVarChar, 12); 
SampParm.Value= "Sample Value"; 
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3. 将 参数 用 于 SqlCommand 


在 将 参数 用 于 SqlCommand 时 ,添加 到 Parameters 集合 的 参数 的 名 称 必 须 与 存储 过 
程 中 参数 标记 的 名 称 相 匹配 。SQL Server . NET Framework 数据 提供 程序 将 存储 过 程 
中 的 参数 视 为 命名 参数 并 搜索 匹配 的 参数 标记 。SQL Server . NET Framework 数据 提 
供 程序 不 支持 在 向 SQL 语句 或 存储 过 程 传递 参数 时 使 用 问号 (?) 占 位 符 。 在 这 种 情况 
下 ,必须 使 用 命名 参数 ,如 以 下 示例 所 示 。 


4. 导出 参数 信息 

参数 也 可 以 使 用 CommandBuilder 类 从 存储 过 程 导出 。SqlCommandBuilder 和 
OleDbCommandBuilder 类 都 提供 了 静态 方法 DeriveParameters ,该 静态 方法 将 自动 使 用 
存储 过 程 中 的 参数 信息 填充 Command 对 象 的 Parameters 集合 。 请 注意 ,DeriveParame- 
ters 将 改写 Command 的 任何 现 有 参数 信息 。 

导出 参数 信息 时 需要 经 历 一 个 到 数据 源 的 附加 行程 ,以 获取 参数 信息 。 如 果 参 数 信 
息 在 设计 时 是 已 知 的 , 则 可 以 通过 显 式 设置 参数 来 提高 应 用 程序 的 性 能 。 

以 下 代码 示例 显示 如 何 使 用 CommandBuilder. DeriveParameters 来 填充 Command 
对 象 的 Parameters 集合 。 
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Catalog= Northwind; Integrated Security= SSPI;"); 

SqlCommand salesCMD= new SqlCommand ("Sales By Year", nwindConn); 
salesCMD.CommandType= CommandType.StoredProcedure; 
nwindConn.Open () 7 

SqlCommandBuilder .DeriveParameters (salesCMD); 

nwindConn.Close (); 


5. 从 数据 库 中 获取 单个 值 

用 户 可 能 需要 返回 只 是 单个 值 的 数据 库 信息 ,而 不 需要 返回 表 或 数据 流 形式 的 数据 
库 信 息 。 例 如 ,可 能 需要 返回 Count( * )、Sum(Price) 或 Avg(Quantity) 等 聚合 函数 的 结 
果 。Command 对 象 使 用 ExecuteScalar 方法 提供 了 返回 单个 值 的 功能 。ExecuteScalar 
方法 以 标量 值 的 形式 返回 结果 集 第 一 行 中 第 一 列 的 值 。 

以 下 代码 示例 使 用 Count 聚合 函数 来 返回 表 中 记录 的 数目 。 


[C#] 
SqlCommand ordersCMD= new SqlCommand ("SELECT Count (* ) FROM Orders", nwindConn); 
Int32 count= (Int32)ordersCMD.ExecuteScalar (); 


6. 执行 数据 库 操作 和 修改 数据 

使 用 . NET Framework 数据 提供 程序 ,可 以 执行 存储 过 程 或 数据 定义 语言 (Data 
Definition Language,DDL) 语 句 ( 如 CREATE TABLE 和 ALTER COLUMN) 来 对 数据 
库 或 目录 执行 架构 操作 。 这 些 命令 不 会 像 查 询 一 样 返回 行 , 因 此 Command 对 象 提供 了 
ExecuteNonQuery 方法 来 处 理 这 些 命令 。 

除了 使 用 ExecuteNonQuery 来 修改 架构 之 外 ,还 可 以 使 用 此 方法 处 理 那 些 修改 数据 
但 不 返回 行 的 SQL 语句 ,如 INSERT、UPDATE 和 DELETE 等 。 

虽然 行 不 是 由 ExecuteNonQuery 方法 返回 的 .但 可 以 通过 Command 对 象 的 Param- 
eters 集合 来 传递 和 返回 输入 及 输出 参数 和 返回 值 。 

7. 执行 目录 操作 

若 要 执行 对 数据 库 或 目录 进行 修改 的 命令 (如 CREATE TABLE 或 CREATE PRO- 
CEDURE 语句 ) ,使 用 相应 的 Transact-SQL 语句 和 Connection 创建 一 个 Command。 使 
用 Command 对 象 的 ExecuteNonQuery 方法 来 执行 该 命令 。 

以 下 代码 示例 在 Microsoft SQL Server 数据 库 中 创建 一 个 存储 过 程 。 


[c#] 
string createStr= "CREATE PROCEDURE InsertCategory "+ 
" @CategoryName nchar(15), "+ 
™ @Identity int OUT "+ 
"AS 
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"INSERT INTO Categories (CategoryName) VALUES (@ Catego- 
ryName) "+ 

"SET @ Identity=@@ Identity "+ 

"RETURN @ @ ROWCOUNT™"; 


SqlCommand createCMD=new SqlCommand (createStr, nwindConn); 
createCMD.ExecuteNonQuery (); 


8. 修改 数据 库 中 的 数据 
修改 数据 的 SQL 语句 (如 INSERT、UPDATE 或 DELETE) 不 返回 行 。 同 样 ,许多 


存储 过 程 


风行 操作 但 不 返回 行 。 若 要 执行 不 返回 行 的 命令 ,使 用 相应 的 SQL 命令 和 


Connection( 以 及 任何 必需 的 Parameters) 创 建 一 个 Command 对 象 ,然后 使 用 该 Com- 
mand 对 象 的 ExecuteNonQuery 方法 。ExecuteNonQuery 方法 返回 一 个 整数 ,表示 受 已 


执行 的 语 
语句 影响 

以 下 
数据 库 中 


[C# 


名 或 存储 过 程 影响 的 行 数 。 如 果 执 行 了 多 个 语句 , 则 返回 的 值 为 受 所 有 已 执行 
的 记录 的 总 数 。 
代码 示例 执行 一 个 INSERT 语句 ,以 使 用 ExecuteNonQuery 将 一 个 记录 插入 


SqlConnection nwindConn=new SqlConnection ("Data Source= localhost; Integrated Security= 


SsPI; 


Initial Catalog=northwind"); 


nwindConn.Open () 7 


string insertStr="INSERT INTO Customers (CustomerID, CompanyName) Values ('NWIND', ' 
Northwind Traders')"; 

SqlCommand insertCMD=new SqlCommand (insertStr, nwindConn); 

Int32 recordsAffected= insertCMD.ExecuteNonQuery (); 


4.3， 


当 执 
法 有 如 下 


3 数据 集 
行 返回 结果 集 的 命令 时 ,需要 一 个 方法 从 结果 集中 提取 数据 。 处 理 结果 集 的 方 


两 个 。 


O@ 使 用 数据 阅读 器 (DataReader) 。 
@ 同时 使 用 数据 适配器 (DataAdapter) 和 ADO. NET 数据 集 (DataSet) 。 


当 确 


定 应 用 程序 应 使 用 DataReader 还 是 应 使 用 DataSet 时 ,应 考虑 应 用 程序 所 需 的 


功能 类 型 。DataSet 用 于 执行 以 下 功能 。 


(1) 
(2) 
的 数据 。 
(3) 


在 层 间或 从 XML Web Services 对 数据 进行 远程 处 理 。 
与 数据 进行 动态 交互 ,例如 绑 定 到 Windows 窗 体 控 件 或 组 合并 关联 来 自 多 个 源 


在 应 用 程序 本 地 缓存 数据 。 
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(4) 提供 关系 数据 的 分 层 XML 视图 并 使 用 XSL 转换 或 XML 路 径 语 言 (XPath) 查 
询 等 工具 来 处 理 数据 。 

(5) 对 数据 执行 大 量 的 处 理 ,而 不 需要 与 数据 源 保持 打开 的 连接 ,从 而 将 该 连接 释放 
给 其 他 客户 端 使 用 。 

如 果 不 需要 DataSet 所 提供 的 功能 , 则 可 以 使 用 DataReader 以 只 进 只 读 方 式 返 回 数 
据 , 从 而 提高 应 用 程序 的 性 能 。 虽 然 DataAdapter 使 用 DataReader 来 填充 DataSet 的 内 
容 , 但 可 以 使 用 DataReader 来 提高 性 能 ,因为 这 样 将 节省 DataSet 所 使 用 的 内 存 , 并 将 省 
去 创建 DataSet 并 填充 其 内 容 所 需 的 必要 处 理 。 

本 节 主 要 讲解 使 用 数据 适配器 和 ADO. NET 数据 集 读 取 数 据 。 下 一 节 讲 述 数据 阅 

1. 从 DataAdapter 填充 DataSet 

ADO. NET DataSet 是 数据 的 内 存 驻 留 表示 形式 , 它 提供 了 独立 于 数据 源 的 一 致 关 
系 编程 模型 。DataSet 表示 整个 数据 集 ,其 中 包含 表 、 约 束 和 表 之 间 的 关系 。 由 于 Data- 
Set 独立 于 数据 源 ,DataSet 可 以 包含 应 用 程序 本 地 的 数据 ,也 可 以 包含 来 自 多 个 数据 源 
的 数据 。 与 现 有 数据 源 的 交互 通过 DataAdapter 来 控制 ,. NET Framework 所 包含 的 每 
个 .NET Framework 数据 提供 程序 都 具有 一 个 DataAdapter 对 象 : OLE DB. NET 
Framework 数据 提供 程序 包含 OleDbDataAdapter 对 象 ,SQL Server. NET Framework 
数据 提供 程序 包含 SqlDataAdapter 对 象 ,ODBC . NET Framework 数据 提供 程序 包含 
OdbcDataAdapter 对 象 。DataAdapter 对 象 用 于 从 数据 源 中 检索 数据 并 填充 DataSet 中 
的 表 。DataAdapter 还 会 将 对 DataSet 作出 的 更 改 解析 回 数 据 源 。DataAdapter 使 用 
.NET Framework 数据 提供 程序 的 Connection 对 象 连接 到 数据 源 ,使 用 Command 对 象 
从 数据 源 中 检索 数据 并 将 更 改 解析 回 数据 源 。 

DataAdapter 的 SelectCommand 属性 是 一 个 Command 对 象 . 它 从 数据 源 中 检索 数 
据 。DataAdapter 的 InsertCommand、UpdateCommand 和 DeleteCommand 属性 也 是 
Command 对 象 , 它 们 按照 对 DataSet 中 数据 的 修改 来 管理 对 数据 源 中 数据 的 更 新 。 

DataAdapter 的 Fill 方法 用 于 使 用 DataAdapter 的 SelectCommand 的 结果 来 填充 
DataSet。Fill 将 要 填充 的 DataSet 和 DataTable 对 象 (或 要 使 用 从 SelectCommand 中 返 
回 的 行 来 填充 DataTable 的 名 称 ) 用 作 它 的 参数 。 

Fill 方法 使 用 DataReader 对 象 来 隐 式 地 返回 用 于 在 DataSet 中 创建 表 的 列 名 称 和 类 
型 ,以 及 用 来 填充 DataSet 中 的 表 行 的 数据 。 表 和 列 仅 在 不 存在 时 才 创 建 ;否则 ,Fill 将 使 
用 现 有 的 DataSet 架构 。 列 类 型 按照 将 . NET Framework 数据 提供 程序 数据 类 型 映射 
到 . NET Framework 数据 类 型 中 的 表 创 建 为 . NET Framework 类 型 。 除 非 数 据 源 中 存 
在 主键 并 且 DataAdapter. MissingSchemaAction 设置 为 MissingSchemaAction. Ad- 
dWithKey ,否则 不 会 创建 主键 。 如 果 Fill 发 现存 在 用 于 某 表 的 主键 ,那么 对 于 其 中 的 主 
键 列 值 与 从 数据 源 中 返回 的 行 的 主键 值 相 匹配 的 行 , 它 将 使 用 数据 源 中 的 数据 改写 
DataSet 中 的 数据 。 如 果 未 找到 任何 主键 , 则 数据 将 追加 到 DataSet 中 的 表 。 当 填充 
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DataSet 时 ,Fill 会 使 用 任何 可 能 存在 的 TableMappings。 
注意 : 如 果 SelectCommand 返回 OUTER JOIN 的 结果 , 则 DataAdapter 不 会 为 结 
果 DataTable 设置 PrimaryKey 值 。 需 要 自己 定义 PrimaryKey 以 确保 正确 解析 重复 行 。 
以 下 代码 示例 创建 DataAdapter 的 一 个 实例 ,该 实例 使 用 Microsoft SQL Server 
Northwind 数据 库 的 Connection 并 使 用 客户 列表 来 填充 DataSet 中 的 DataTable。 向 
DataAdapter 构造 函数 传递 的 SQL 语句 和 Connection 参数 用 于 创建 DataAdapter 的 Se- 
lectCommand 属性 。 


[Cc#] 
SqlConnection nwindConn=new SqlConnection ("Data Source= localhost; Integrated Security= 
SSPI;Initial Catalog=northwind"); 


SqlCommand selectCMD=new SqlCommand ("SELECT CustomerID, CompanyName FROM Customers", 
nwindConn); 
selectCMD.CommandTimeout= 30; 


SqlDataAdapter custDA=new SqlDataAdapter (); 
CustDA.SelectCommand= selectCMD; 


nwindConn.Open () 7 


DataSet custDS=new DataSet ()? 
CustDA.Fill (custDS, "Customers"); 


nwindConn.Close(); 


注意 : 该 代码 不 显 式 打开 和 关闭 Connection。 如 果 Fill 方法 发 现 连 接 尚 未 打开 , 它 
将 隐 式 地 打开 DataAdapter 正在 使 用 的 Connection。 如 果 Fill 已 打开 连接 , 它 还 将 在 Fill 
完成 时 关闭 连接 。 当 处 理 单一 操作 (如 Fill 或 Update) 时 ,这 可 以 简化 用 户 的 代码 。 但 
是 ,如 果 在 执行 多 项 需要 打开 连接 的 操作 , 则 可 以 通过 以 下 方式 提高 应 用 程序 的 性 能 : 显 
式 调 用 Connection 的 Open 方法 ,对 数据 源 执行 操作 ,然后 调用 Connection 的 Close 方 
法 。 为 了 释放 资源 供 其 他 客户 端 应 用 程序 使 用 .应 设法 使 与 数据 源 的 连接 打开 尽 可 能 短 
的 时 间 。 

2. 多 个 结果 集 

如 果 DataAdapter 遇 到 多 个 结果 集 , 它 将 在 DataSet 中 创建 多 个 表 。 将 向 这 些 表 提 
供 递增 的 默认 名 称 TableN ,以 表示 Table0 的 Table 为 第 一 个 表 名 。 如 果 以 参数 形式 向 
Fill 方 法 传递 表 名 称 , 则 将 向 这 些 表 提 供 递 增 的 默认 名 称 TableNameN, 这 些 表 名 称 以 表 
示 TableName0 的 TableName 为 起 始 。 

3. 从 多 个 DataAdapter 填充 DataSet 


可 以 将 任意 数量 的 DataAdapter 与 一 个 DataSet 一 起 使 用 。 每 个 DataAdapter 都 可 
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用 于 填充 一 个 或 多 个 DataTable 对 象 并 将 更 新 解析 回 相关 数据 源 。DataRelation 和 Con- 
straint 对 象 可 以 在 本 地 添加 到 DataSet, 这 样 ,就 可 以 使 来 自 多 个 不 同 数据 源 的 数据 相关 
联 。 例 如 ,DataSet 可 以 包含 来 自 Microsoft SQL Server 数据 库 、 通 过 OLE DB 公开 的 
IBM DB2 数据 库 及 对 XML 进行 流 处 理 的 数据 源 的 数据 。 一 个 或 多 个 DataAdapter 对 象 
可 以 处 理 与 每 个 数据 源 的 通信 。 

以 下 代码 示例 从 Microsoft SQL Server 2000 上 的 Northwind 数据 库 填充 客户 列表 ， 
从 存储 在 Microsoft Access 2000 中 的 Northwind 数据 库 填充 订单 列表 。 已 填充 的 表 通 
过 DataRelation 相关 联 , 然 后 客户 列表 将 与 相应 客户 的 订单 一 起 显示 出 来 。 
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4. 使 用 DataAdapter 和 DataSet 更 新 数据 库 

DataAdapter 的 Update 方法 可 调用 来 将 DataSet 中 的 更 改 解析 回 数据 源 。 与 Fill 方 
法 类 似 ,Update 方法 将 DataSet 的 实例 和 可 选 的 DataTable 对 象 或 DataTable 名 称 用 作 
参数 。DataSet 实例 是 包含 已 作出 更 改 的 DataSet, 而 DataTable 标识 从 其 中 检索 更 改 
的 表 。 

当 调用 Update 方法 时 ,DataAdapter 将 分 析 已 作出 的 更 改 并 执行 相应 的 命令 (IN- 
SERT UPDATE 或 DELETE)。 当 DataAdapter 遇 到 对 DataRow 的 更 改 时 , 它 将 使 用 
InsertCommand、UpdateCommand 或 DeleteCommand 来 处 理 该 更 改 。 这 样 ,就 可 以 通过 
在 设计 时 指定 命令 语法 ,并 在 可 能 时 通过 使 用 存储 过 程 来 尽量 提高 ADO. NET 应 用 程序 
的 性 能 。 在 调用 Update 之 前 ,必须 显 式 设置 这 些 命令 。 如 果 调 用 了 Update 但 不 存在 用 
于 特定 更 新 的 相应 命令 (例如 ,不 存在 用 于 已 删除 行 的 DeleteCommand) , 则 将 引发 异常 。 

Command 参数 可 用 于 为 DataSet 中 每 个 已 修改 行 的 SQL 语句 或 存储 过 程 指定 输入 
和 输出 值 。 

如 果 DataTable 映射 到 单个 数据 库 表 或 从 单个 数据 库 表 生成 , 则 可 以 利用 Com- 
mandBuilder 对 象 自动 生成 DataAdapter 的 DeleteCommand InsertCommand 和 Update- 
Command, 

Update 方法 会 将 更 改 解析 回 数据 源 ,但 是 自 上 次 填充 DataSet 以 来 ,其 他 客户 端 可 
能 已 修改 了 数据 源 中 的 数据 。 若 要 使 用 当前 数据 刷新 DataSet, 则 再 次 使 用 DataAdapter 
填充 (Fill)DataSet。 新 行将 添加 到 该 表 中 ,更 新 的 信息 将 并 入 现 有 行 。Fill 方 法 通过 检 
查 DataSet 中 行 的 主键 值 及 SelectCommand 返回 的 行 来 确定 是 否 要 添加 一 个 新 行 或 更 新 
现 有 行 。 如 果 Fill 方法 发 现 DataSet 中 某 行 的 主键 值 与 SelectCommand 返回 结果 中 某 行 
的 主键 值 相 匹配 , 则 它 将 用 SelectCommand 返回 的 行 中 的 信息 更 新 现 有 行 ,并 将 现 有 行 
的 RowState 设置 为 Unchanged。 如 果 SelectCommand 返回 的 行 所 具有 的 主键 值 与 
DataSet 中 行 的 任何 主键 值 都 不 匹配 , 则 Fill 方法 将 添加 RowState 为 Unchanged 的 
新 行 。 

注意 : 如 果 SelectCommand 返回 OUTER JOIN 的 结果 , 则 DataAdapter 不 会 为 结 
果 DataTable 设置 PrimaryKey 值 。 需 要 自己 定义 PrimaryKey 以 确保 正确 解析 重复 行 。 

若 要 处 理 可 能 在 Update 操作 过 程 中 发 生 的 异常 ,可 以 使 用 RowUpdated 事件 在 这 
些 异常 发 生 时 响应 行 更 新 错误 ,或 者 可 以 在 调用 Update 之 前 将 DataAdapter. Continue- 
UpdateOnError 设置 为 true, 然 后 在 Update 完成 时 响应 存储 在 特定 行 的 RowError 属性 
中 的 错误 信息 。 

注意 : 如 果 对 DataSet、DataTable 或 DataRow 调用 AcceptChanges, 则 将 使 一 个 Da- 
taRow 的 所 有 Original 值 都 被 改写 为 该 DataRow 的 Current 值 。 如 果 已 修改 将 该 行 标 
识 为 唯一 行 的 字段 值 ,那么 当 调用 AcceptChanges 后 ,Original 值 将 不 再 匹配 数据 源 中 
的 值 。 

以 下 示例 演示 如 何 通 过 显 式 设置 DataAdapter 的 UpdateCommand 来 执行 对 已 修改 
行 的 更 新 。 请 注意 , 在 UPDATE 语句 的 WHERE 子 句 中 指定 的 参数 设置 为 使 用 
SourceColumn 的 Original 值 。 这 一 点 很 重要 ,因为 Current 值 可 能 已 被 修改 ,并 且 可 能 
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不 匹配 数据 源 中 的 值 。Original 值 是 曾 用 来 从 数据 源 填充 DataTable 的 值 。 


[Cc#] 
SqlDataAdapter catDA= new SqlDataAdapter ("SELECT CategoryID, CategoryName FROM Catego- 
ries",nwindConn); 
CatDA.UpdateCommand=new SqlCommand ("UPDATE Categories SET CategoryName=@ CategoryName ™ 
+ "WHERE CategoryID=@ CategoryID", nwindConn); 
catDR.UpdateCommand. Parameters.Add ("@ CategoryName", SqlDbType.NVarChar, 15, "Catego- 
ryName"); 
SqlParameter workParm= catDA. UpdateCommand. Parameters. Rdd ("@ CategoryID", SqlDbType. 
Int); 
workParm.SourceColumn= "CategoryID"; 
workParm.SourceVersion= DataRowVersion.Original; 
DataSet catDS=new DataSet (); 
CatDA.Fill (catDS, "Categories"); 
DataRow cRow= catDS.Tables["Categories"] .Rows[0]; 
cRow["CategoryName"]= "New Category"; 
CatDA.Update (catDS) 7 


5. 自动 递增 列 

如 果 来 自 数据 源 的 表 包 含 自动 递增 列 , 则 可 以 使 用 由 数据 源 生成 的 值 填充 DataSet 
中 的 列 ,方法 是 通过 以 存储 过 程 输出 参数 的 形式 返回 自动 递增 值 并 将 其 映射 到 表 中 的 一 
列 ,或 者 使 用 DataAdapter 的 RowUpdated 事件 。 

但 是 ,DataSet 中 的 值 可 能 会 与 数据 源 中 的 值 不 同步 并 导致 意外 的 行为 。 例 如 ,请 考 
虑 一 个 包含 自动 递增 主键 列 CustomerID 的 表 。 如 果 在 该 DataSet 中 添加 两 个 新 客户 , 它 
们 将 收 到 自动 递增 的 CustomerId 值 1 和 2。 在 向 DataAdapter 的 Update 方法 传递 第 二 
个 客户 行 时 ,新 添加 的 行 会 收 到 数据 源 中 的 自动 递增 CustomerID 值 1, 该 值 与 DataSet 
中 的 值 2 不 匹配 。 当 DataAdapter 使 用 返回 值 填充 DataSet 中 的 行 时 ,由 于 第 一 个 客户 
行 的 CustomerID 已 经 是 1, 因 此 将 发 生 约束 冲突 。 为 了 避免 这 种 行为 ,建议 在 使 用 数据 
源 中 的 自动 递增 列 和 DataSet 中 的 自动 递增 列 时 ,在 DataSet 中 创建 AutoIncrementStep 
为 一 1 且 AutoIncrementSeed 为 0 的 列 , 并 确保 数据 源 生成 从 1 开始 并 以 正 步 长 值 递 增 
的 自动 递增 标识 值 。 这 样 ,DataSet 将 为 自动 递增 值 生成 负数 ,这 些 负 数 不 会 与 数据 源 所 
生成 的 正 自动 递增 值 发 生 冲 突 。 另 一 种 方法 是 使 用 Guid 类 型 的 列 而 不 是 自动 递增 列 。 
生成 Guid 值 的 算法 在 DataSet 中 生成 的 Guid 不 会 与 数据 源 生成 的 Guid 相同 。 

6. 插入 、 更 新 和 删除 的 排序 

在 许多 情况 下 ,以 何 种 顺序 向 数据 源 发 送 通 过 DataSet 作出 的 更 改 是 相当 重要 的 。 
例如 ,如 果 已 更 新 现 有 行 的 主键 值 并 且 添加 了 具有 新 主键 值 的 新 行 , 则 务必 要 在 处 理 插入 
之 前 处 理 更 新 。 可 以 使 用 DataTable 的 Select 方法 来 返回 仅 引 用 具有 特定 RowState 的 
DataRow 数组 。 然 后 可 以 将 返回 的 DataRow 数组 传递 到 DataAdapter 的 Update 方法 来 
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处 理 已 修改 的 行 。 通 过 指定 要 更 新 的 行 的 子 集 ,可 以 控制 处 理 插入 、 更 新 和 删除 的 顺序 。 


例如 ,以 下 代码 确保 首先 处 理 表 中 已 删除 的 行 .然后 处 理 已 更 新 的 行 ,然后 处 理 已 插 
入 的 行 。 
[C#] 


DataTable updTable= custDS .Tables ["Customers"]; 

// First process deletes. 

CustDA.Update (updTable.Select (null, null, DataViewRowState.Deleted)); 

// Next process updates. 

custDR.Update (updTable.Select (null, null, DataViewRowState.ModifiedCurrent)); 
// Finally, process inserts. 

custDR.Update (updTable.Select (null, null, DataViewRowState.Added)); 


7. 向 DataSet 添加 现 有 约束 

DataAdapter 的 Fill 方法 仅 使 用 数据 源 中 的 表 列 和 表 行 来 填充 DataSet。 虽 然 约 束 
通常 由 数据 源 来 设置 ,但 在 默认 情况 下 ,Fill 方 法 不 会 将 此 架构 信息 添加 到 DataSet 中 。 
车 要 使 用 数据 源 中 的 现 有 主键 约束 信息 填充 DataSet, 则 可 以 调用 DataAdapter 的 
FillSchema 方法 ,或 者 在 调用 Fill 之 前 将 DataAdapter 的 MissingSchemaAction 属性 设 
置 为 AddWithKey。 这 将 确保 DataSet 中 的 主键 约束 反映 数据 源 中 的 主键 约束 。 外 键 约 
束 信息 不 包含 在 内 ,将 需要 显 式 创建 。 

如 果 在 使 用 数据 填充 DataSet 之 前 向 其 中 添加 架构 信息 .将 确保 将 主键 约束 与 Data- 
Set 的 DataTable 对 象 包含 在 一 起 。 这 样 , 当 再 次 调用 Fill 来 填充 DataSet 时 ,将 使 用 主 
键 列 信息 来 匹配 数据 源 中 的 新 行 和 每 个 DataTable 中 的 当前 行 ,并 且 使 用 数据 源 中 的 数 
据 改写 表 中 的 当前 数据 。 如 果 没 有 架构 信息 ,来 自 数据 源 的 新 行将 追加 到 DataSet ,从 而 
导致 重复 的 行 。 

注意 : 如 果 数据 源 中 的 某 列 被 标识 为 自动 递增 列 , 则 MissingSchemaAction 为 Ad- 
dWithKey 的 FillSchema 方法 或 Fill 方法 创建 一 个 AutoIncrement 属性 设置 为 true 的 
DataColumn。 不 过 ,用 户 将 需要 手动 设置 AutoIncrementStep 和 AutoIncrementSeed 值 。 

当 使 用 FillSchema 或 将 MissingSchemaAction 设置 为 AddWithKey 时 ,将 需要 在 数 
据 源 中 进行 额外 的 处 理 来 确定 主键 列 信息 。 这 一 额外 的 处 理 可 能 会 降低 性 能 。 如 果 主 键 
信息 在 设计 时 已 知 , 为 了 实现 最 佳 性 能 ,建议 显 式 指定 一 个 或 多 个 主键 列 。 

以 下 代码 示例 显示 如 何 使 用 FillSchema 向 DataSet 添加 架构 信息 。 


[C#] 
DataSet custDS=new DataSet (); 
CustDA.FillSchema (custDS, SchemaType.Source, "Customers"); 
custDA.Fill (custDS, "Customers"); 


以 下 代码 示例 显示 如 何 使 用 Fill 方法 的 MissingSchemaAction. AddWithKey 属性 向 
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DataSet 添加 架构 信息 。 


[C#] 
DataSet custDS=new DataSet (); 
custDA.MissingSschemaAction=MissingSchemaAction.AddWithKey; 
CustDA.Fill (custDS, "Customers"); 


如 果 DataAdapter 遇 到 从 SelectCommand 中 返回 的 多 个 结果 集 , 它 将 在 DataSet 中 
创建 多 个 表 。 将 向 这 些 表 提供 递增 的 默认 名 称 TableN ,以 表示 Table0 的 Table 为 第 一 
个 表 名 。 如 果 以 参数 形式 向 FillSchema 方法 传递 表 名 称 , 则 将 向 这 些 表 提供 递增 的 默认 
名 称 TableNameN, 这 些 表 名 称 以 表示 TableName0 的 TableName 为 起 始 。 

注意 : 如 果 对 返回 多 个 结果 集 的 命令 调用 OleDbDataAdapter 对 象 的 FillSchema 方 
法 , 则 将 只 返回 第 一 个 结果 集中 的 架构 信息 。 当 使 用 OleDbDataAdapter 为 多 个 结果 集 
返回 架构 信息 时 ,建议 在 调用 Fill 方法 时 将 MissingSchemaAction 指定 为 AddWithKey 
并 获取 架构 信息 。 

8. 设置 DataTable 和 DataColumn 映射 

DataAdapter 在 其 TableMappings 属性 中 包含 0 个 或 更 多 个 DataTableMapping 对 
象 的 集合 。DataTableMapping 提供 对 数据 源 的 查询 所 返回 的 数据 与 DataTable 之 间 的 
主 映射 。DataTableMapping 名 称 可 以 代替 DataTable 名 称 传递 到 DataAdapter 的 Fill 
方法 。 以 下 示例 为 MyAuthors 表 创 建 名 为 AuthorsMapping 的 DataTableMapping。 


[Cc#] 
workAdapter .TableMappings.Add ("AuthorsMapping", "MyAuthors"); 


DataTableMapping 使 用 户 能 够 使 用 DataTable 中 与 数据 库 中 的 列 名 不 同 的 列 名 。 
当 该 表 被 更 新 时 ,DataAdapter 将 使 用 此 映射 来 匹配 列 。 

如 果 在 调用 DataAdapter 的 Fill 或 Update 方法 时 未 指定 TableName 或 DataT- 
ableMapping 名 称 ,DataAdapter 将 查找 名 为 Table 的 DataTableMapping。 如 果 DataT- 
ableMapping 不 存在 ,DataTable 的 TableName 将 为 Table。 可 以 通过 创建 名 为 Table 的 
DataTableMapping 来 指定 默认 的 DataTableMapping。 

以 下 代码 示例 创建 一 个 DataTableMapping( 从 System. Data. Common 命名 空间 ) 并 
通过 将 其 命名 为 Table 来 使 其 成 为 指定 DataAdapter 的 默认 映射 。 然 后 ,该 示例 将 查询 
结果 中 第 一 个 表 (Northwind 数据 库 的 Customers 表 ) 中 的 列 映 射 到 DataSet 的 North- 
wind Customers 表 中 的 一 组 更 为 用 户 友 好 的 名 称 。 对 于 未 映射 的 列 , 将 使 用 数据 源 中 的 
列 名 称 。 


[C#] 
DataTableMapping custMap= custDA.TableMappings.Add ("Table", "NorthwindCustomers"); 
custMap.ColumnMappings.Add( "CompanyName", "Company"); 
custMap.ColumnMappings.Add ( "ContactName”", "Contact"); 
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custMap.ColumnMappings.Rdd( "PostalCode", "ZIPCode"); 
CustDA.Fill (custDS) > 


在 更 为 复杂 的 情况 下 ,用 户 可 能 会 决定 需要 使 用 相同 的 DataAdapter 来 支持 为 不 同 
的 表 加 载 不 同 的 映射 。 若 要 完成 此 任务 ,只 需 添 加 附加 的 DataTableMapping 对 象 。 

当 Fill 方法 以 DataSet 实例 和 DataTableMapping 名 称 的 形式 进行 传递 时 ,如 果 存 在 
具有 该 名 称 的 映射 , 则 使 用 该 映射 ;否则 将 使 用 具有 该 名 称 的 DataTable。 

以 下 示例 创建 一 个 名 称 为 Customers, 而 DataTable 名 称 为 BizTalkSchema 的 
DataTableMapping。 然 后 ,该 示例 将 SELECT 语句 所 返回 的 行 映射 到 BizTalkSchema 
DataTable。 


[C#] 
ITableMapping bizMap= custDA.TableMappings.Add ("Customers", "BizTalkschema"); 
bizMap.ColumnMappings .Rdd( "CustomerID", "ClientID"); 
bizMap.ColumnMappings .Rdd( "CompanyName", "ClientName"); 
bizMap.ColumnMappings.Add ( "ContactName", "Contact"); 
bizMap.ColumnMappings.Rdd( "PostalCode", "ZIP"); 
CustDA.Fill (custDS, "Customers"); 


注意 : 如 果 没 有 为 列 映射 提供 源 列 名 称 或 者 没有 为 表 映 射 提供 源 表 名 称 , 则 将 自动 
生成 默认 名 称 。 如 果 没 有 为 列 映射 提供 源 列 , 则 将 给 列 映射 提供 递增 的 默认 名 称 
SourceColumnN, 这 些 名 称 从 SourceColumnl 开始 。 如 果 没 有 为 表 映 射 提供 源 表 名 称 ， 
则 将 给 该 表 映 射 提供 递增 的 默认 名 称 SourceTableN ,这 些 名 称 从 SourceTablel 开始 。 

建议 在 为 列 映射 提供 源 列 名 称 时 避免 使 用 SourceColumnN 命名 约定 ,在 为 表 映 射 提 
供 源 表 名 称 时 避免 使 用 SourceTableN 命名 约定 ,因为 所 提供 的 名 称 可 能 会 与 Column- 
MappingCollection 中 现 有 的 默认 列 映射 名 称 或 DataTableMappingCollection 中 的 表 映 
射 名 称 发 生 冲 突 。 如 果 提 供 的 名 称 已 经 存在 ,将 引发 异常 。 

如 果 SelectCommand 返回 多 个 表 ,Fill 将 自动 使 用 递增 值 为 DataSet 中 的 表 生成 表 
名 称 , 这 些 表 名 称 从 指定 表 名 称 开 始 , 并 以 TableNameN 格式 (从 TableNamel 开始 ) 继 
续 。 可 以 使 用 表 映 射 将 自动 生成 的 表 名 称 映射 到 要 为 DataSet 中 的 表 指 定 的 名 称 。 例 
如 ,对 于 返回 两 个 表 (Customers 和 Orders) 的 SelectCommand, 可 对 Fill 发 出 以 下 调用 : 


CustDA.Fill (custDS, "Customers") 


在 DataSet 中 创建 了 两 个 表 : Customers 和 Customers1。 可 以 使 用 表 映 射 来 确保 第 
二 个 表 名 为 Orders 而 不 是 Customers1。 若 要 完成 此 任务 , 则 将 Customersl 的 源 表 映射 
到 DataSet 表 Orders, 如 以 下 示例 所 示 : 


custDA.TableMappings.Add ("Customersl", "Orders") 
CustDA.Fil]l (custDS, "Customers") 
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9. 将 参数 用 于 DataAdapter 

DataAdapter 具有 4 项 用 于 从 数据 源 检 索 数 据 和 向 数据 源 更 新 数据 的 属性 。Select- 
Command 属性 从 数据 源 中 返回 数据 。InsertCommand、UpdateCommand 和 DeleteCom- 
mand 属性 用 于 管理 数据 源 中 的 更 改 。 在 调用 DataAdapter 的 Fill 方法 之 前 ,必须 设置 
SelectCommand 属性 。 根 据 对 DataSet 中 的 数据 作出 的 更 改 , 在 调用 DataAdapter 的 
Update 方法 之 前 ,必须 设置 InsertCommand、UpdateCommand 或 DeleteCommand 属性 。 
例如 ,如 果 已 添加 行 ,在 调用 Update 之 前 必须 设置 InsertCommand。 当 Update 处 理 已 
插入 、 更 新 或 删除 的 行 时 ,DataAdapter 将 使 用 相应 的 Command 属性 来 处 理 该 操作 。 有 
关 已 修改 行 的 当前 信息 将 通过 Parameters 集合 传递 到 Command 对 象 。 

例如 , 当 更 新 数据 源 中 的 行 时 ,将 调用 UPDATE 语句 , 它 使 用 唯一 标识 符 来 表示 该 
表 中 要 更 新 的 行 。 该 唯一 标识 符 通常 是 主键 字段 的 值 。UPDATE 语句 使 用 既 包 含 唯一 
标识 符 又 包含 要 更 新 的 列 和 值 的 参数 ,如 以 下 SQL 语句 所 示 : 


UPDATE Customers SET CompanyName= @ CompanyName WHERE CustomerID=@CustomerID 


在 该 示例 中 ,将 其 中 CustomerID 等 于 @CustomerID 参数 值 的 行 的 CompanyName 
字段 用 @ CompanyName 参数 值 来 进行 更 新 。 这 些 参数 使 用 Parameter 对 象 的 
SourceColumn 属性 从 已 修改 的 行 中 检索 相关 信息 。 下 面 是 上 一 示例 UPDATE 语句 的 
参数 : 


CustDA.Parameters.Add ("@ CompanyName", SqlDbType.NChar, 15, "CompanyName") 

Dim myParm Rs SqlParameter= custDA.UpdateCommand.Parameters.Add("@ CustomerID", _ 
SqlDbType .NChar, 5, "CustomerID") 

myParm.SourceVersion= DataRowVersion.Original 


Parameters 集合 的 Add 方法 采用 参数 的 名 称 、DataAdapter 特定 类 型 .大 小 (如 果 可 
应 用 于 该 类 型 ) 及 DataTable 中 SourceColumn 的 名 称 。 注意, @ CustomerID 参数 的 
SourceVersion 设置 为 Original。 这 样 , 如 果 标 识 列 的 值 已 经 在 修改 后 的 DataRow 中 被 更 
改 , 就 一 定 会 更 新 数据 源 中 的 现 有 行 。 在 这 种 情况 下 ,Original 行 值 将 匹配 数据 源 中 的 当 
前 值 ,而 Current 行 值 将 包含 更 新 的 值 。 如 果 没 有 为 @CompanyName 参数 设置 Source- 
Version, 而 将 使 用 默认 的 Current 行 值 。 

以 下 示例 显示 要 用 作 DataAdapter 的 SelectCommand、 InsertCommand、Update- 
Command 和 DeleteCommand 属性 的 CommandText 的 示例 SQL 语句 。 对 于 OleDb- 
DataAdapter 对 象 和 OdbcDataAdapter 对 象 .必须 使 用 占 位 符 来 标识 参数 。 对 于 Sql- 
DataAdapter 对 象 , 必 须 使 用 命名 参数 。 


[Cc#] 
string selectSQI= "SELECT CustomerID, CompanyName FROM Customers WHERE Country=@ Country 
AND City=@City"; 
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string insertSQLI= "INSERT INTO Customers (CustomerID, CompanyName) "+ 
"VALUES (@ CustomerID, @CompanyName)"; 

string updateSQI "UPDATE Customers SET CustomerID=@ CustomerID, CompanyName= 

@ CompanyName "+ "WHERE CustomerID=@OldCustomerID"; 

string deleteSQI "DELETE FROM Customers WHERE CustomerID=@ CustomerID"; 


参数 化 查询 语句 定义 将 需要 创建 哪些 输入 和 输出 参数 。 若 要 创建 参数 , 则 使 用 Pa- 
rameters. Add 方法 或 Parameter 构造 函数 来 指定 列 名 称 、 数 据 类 型 和 大 小 。 对 于 内 部 数 
据 类 型 (如 Integer) ,无 须 包 含 大 小 或 者 可 以 指定 默认 大 小 。 

以 下 代码 示例 为 上 一 示例 中 的 SQL 语句 创建 参数 并 填充 DataSet 。 


[Cc#] 

SqlConnection nwindConn=new SqlConnection ("Data Source= localhost;Integrated Security= 
SSPI;Initial Catalog=northwind"); 

SqlDataAdapter custDA=new SqlDataAdapter (); 

SqlCommand selectCMD= new SqlCommand (selectSQL, nwindConn); 
CustDA.SelectCommand= selectCMD; 

// add parameters and set values. 

selectCMD.Parameters.Add ("@ Country", SqlDbType.NVarChar, 15) .Value= "UK"; 
selectCMD.Parameters.Add ("@ City", SqlDbType.NVarChar, 15) .Value= "London"; 
DataSet custDS= new DataSet (); 

custDA.Fill (custDS, "Customers"); 


10. Parameter. DbType 

参数 的 类 型 是 特定 于 . NET Framework 数据 提供 程序 的 。 如 果 指 定 类 型 , 则 在 向 数 
据 源 传递 Parameter 的 值 之 前 ,会 将 该 值 转换 为 . NET Framework 数据 提供 程序 类 型 。 
如 果 未 指定 类 型 ,ADO. NET 将 从 Parameter 对 象 的 Value 的 . NET Framework 类 型 推 
断 Parameter 的 . NET Framework 数据 提供 程序 类 型 。 也 可 以 通过 将 Parameter 对 象 的 
DbType 属性 指定 为 特定 的 System. Data. DbType, 以 一 般 的 方式 来 指定 Parameter 的 类 
型 。 此 外 ,ADO. NET 将 从 Parameter 对 象 的 DbType 推断 Parameter 的 . NET Frame- 
work 数据 提供 程序 类 型 。Parameter 对 象 的 . NET Framework 数据 提供 程序 类 型 将 从 
Parameter 对 象 的 Value 的 . NET Framework 类 型 来 推断 ,或 从 Parameter 对 象 的 Db- 
Type 来 推断 。 表 4-4 显示 了 根据 作为 Parameter 值 或 指定 的 DbType 传递 的 对 象 推断 出 
的 Parameter 类 型 。 

注意 : 随 . NET Framework 1. 0 版 提供 的 . NET Framework 数据 提供 程序 不 验证 
Decimal 参数 值 的 Precision 和 Scale, 这 可 能 会 导致 截断 的 数据 被 插入 数据 源 。 如 果 使 用 
的 是 . NET Framework 1. 0 版 ,请 在 设置 参数 值 之 前 .验证 Decimal 值 的 Precision 和 


Scale。 
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表 4-4 Parameter 类 型 


类 型 System. Data. DbType SqlDbType 

bool Boolean Bit 

byte Byte TinyInt 
VarBinary。 如 果 字 节 数 组 大 于 8000 字 节 ,此 隐 式 转换 将 

byte[] Binary 失败 。 对 于 大 于 8000 字 节 的 字 节 数 组 , 则 显 式 设置 SqlD- 
bType 

char 不 支持 从 char 推断 SqlDbType 

DateTime DateTime DateTime 

Decimal Decimal Decimal 

double Double Float 

float Single Real 

Guid Guid Uniqueldentifier 

Int16 Int16 SmallInt 

Int32 Int32 Int 

Int64 Int64 BitInt 

object Object Variant 

区 ig NVarChar。 如 果 字 符 申 大 于 4000 字 节 ,此 隐 式 转换 将 失 
败 。 对 于 大 于 4000 字符 的 字符 串 ,请 显 式 设 置 SqlDbType 

TimeSpan Time 不 支持 从 TimeSpan 推断 SqlDbType 

UInt16 UInt16 不 支持 从 UInt16 推断 SqlDbType 

UInt32 UInt32 不 支持 从 UInt32 推断 SqlDbType 

UInt64 UInt64 不 支持 从 UInt64 推断 SqlDbType 


在 .NET Framework 1. 1 版 及 更 高 版 本 中 , 当 用 无 效 的 Precision 设置 Decimal 参数 
值 时 会 发 生 异 常 。 但 仍 将 截断 超出 Decimal 参数 小 数位 数 的 Scale 值 。 
11. Parameter. Direction 


表 4-5 显示 可 以 与 ParameterDirection 枚 举 一 起 用 来 设置 Parameter 的 Direction 的 值 。 


表 4-5 Direction 值 


成 员 名 称 说 有 明 
Input 该 参数 是 输入 参数 。 这 是 默认 设置 
InputOutput 该 参数 能 够 输入 和 输出 
Output 该 参数 是 输出 参数 
ReturnValue 该 参数 表示 返回 值 
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以 下 代码 示例 显示 如 何 设 置 Parameter 的 Direction。 

myParm.Direction= ParameterDirection.Output 

SourceColumn 和 SourceVersion 可 以 作为 参数 传递 到 Parameter 构造 函数 ,或 设置 
为 现 有 Parameter 的 属性 。SourceColumn 是 来 自 将 在 其 中 检索 Parameter 值 的 Da- 
taRow 的 DataColumn 的 名 称 。SourceVersion 指定 DataAdapter 使 用 哪个 DataRow 版 
本 来 检索 值 。 

表 4-6 显示 可 以 与 SourceVersion 一 起 使 用 的 DataRowVersion 枚 举 值 。 


表 4-6 ”DataRowVersion 枚 举 值 


成 员 名 称 说 明 
Current 该 参数 使 用 列 的 当前 值 。 这 是 默认 设置 
Default 该 参数 使 用 列 的 DefaultValue 
Original 该 参数 使 用 列 的 初始 值 
Proposed 该 参数 使 用 建议 值 


以 下 代码 示例 定义 一 个 UPDATE 语句 ,在 该 语句 中 ,CustomerID 列 用 作 以 下 两 个 
参数 的 SourceColumn: @CustomerID(SET CustomerID=@CustomerID) 和 @OldCus- 
tomerID( WHERE CustomerID== @ OldCustomerID)。@ CustomerID 参数 用 于 将 Cus- 
tomerID 列 更 新 为 DataRow 中 的 当前 值 。 因 此 ,将 使 用 SourceVersion 为 Current 的 
CustomerID SourceColumn。@OldCustomerID 参数 用 于 标识 数据 源 中 的 当前 行 。 由 于 
在 该 行 的 Original 版 本 中 找到 了 匹配 列 值 ,所 以 将 使 用 SourceVersion 为 Original 的 相同 


SourceColumn(CustomerID)。 


[Cc#] 

custDA.UpdateCommand.Parameters.Add("@ CustomerID", SqlDbType.NChar, 5, "CustomerID"); 
custDA.UpdateCommand. Parameters. Rdd ( "@ CompanyName", SqlDbType. NVarChar, 40, "Com- 
panyName"); 

SqlParameter myParm= custDA. UpdateCommand. Parameters.Add ("@ OldCustomerID", SqlDbType. 
NChar, 5, "CustomerID"); 

myParm.SourceVersion= DataRowVersion.Original; 


12. UpdateDRowSource 

可 以 使 用 Command 对 象 的 UpdatedRowSource 属性 控制 从 数据 源 中 返回 的 值 如 何 
映射 回 DataSet。 通 过 将 UpdateDRowSource 属性 设置 为 UpdateRowSource 枚 举 值 之 
一 ,可 以 控制 是 忽略 DataAdapter 命令 返回 的 参数 还 是 将 其 应 用 于 DataSet 中 已 更 改 的 
行 。 还 可 以 指定 是 否 将 返回 的 第 一 个 行 (如 果 存 在 ) 应 用 于 DataSet 中 已 更 改 的 行 。 

表 4-7 描述 了 UpdateRowSource 枚 举 的 不 同 值 ,并 说 明 它们 如 何 影响 与 DataAdapter 一 
起 使 用 的 命令 的 行为 。 
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表 4-7 UpdateRowSource 的 枚 举 值 


UpdateRowSource 说 明 
Both 输出 参数 和 返回 结果 集 的 第 一 行 都 可 以 映射 到 DataSet 中 已 更 改 的 行 
FirstReturnedRecord 只 有 返回 的 结果 集 第 一 行 中 的 数据 才 可 以 映射 到 DataSet 中 已 更 改 的 行 
None 将 忽略 任何 输出 参数 或 返回 结果 集 的 行 
OutputParameters 只 有 输出 参数 才 可 以 映射 到 DataSet 中 已 更 改 的 行 


13. 输入 和 输出 参数 及 返回 值 

除了 输入 和 输出 参数 之 外 ,存储 过 程 还 可 以 具有 返回 值 。 以 下 示例 阐释 ADO. NET 
如 何 发 送 和 接收 输入 参数 ,输出 参数 和 返回 值 , 其 中 采用 了 这 样 一 种 常见 方案 : 将 新 记录 
插入 其 中 主键 列 是 自动 编号 字段 的 表 。 该 示例 使 用 输出 参数 来 返回 自动 编号 字段 的 @@ 
Identity, 而 DataAdapter 则 将 其 绑 定 到 DataTable 的 列 , 使 DataSet 反映 所 生成 的 主 
键 值 。 

该 示例 使 用 以 下 存储 过 程 将 新 目录 插入 Northwind Categories 表 ( 该 表 将 Catego- 
ryName 列 中 的 值 当 作 输入 参数 ) ,从 @@Identity 中 以 输出 参数 的 形式 返回 自动 编号 字 
段 CategoryID 的 值 ,并 提供 所 影响 行 数 的 返回 值 。 


CREATE PROCEDURE InsertCategory 
@ CategoryName nchar (15), 
@ Identity int OUT 
RS 
INSERT INTO Categories (CategoryName) VALUES (@ CategoryName) 
SET @ Identity=@ @ Identity 
RETURN @ @ ROWCOUNT 


以 下 示例 将 InsertCategory 存储 过 程 用 作 DataAdapter 的 InsertCommand 的 数据 
源 。 通 过 将 CategoryID 列 指定 为 @Identity 输出 参数 的 SourceColumn, 当 调 用 Data- 
Adapter 的 Update 方法 时 ,所 生成 的 自动 编号 值 将 在 该 记录 插入 数据 库 后 在 DataSet 中 
得 到 反映 。 

对 于 OleDbDataAdapter, 必须 在 指定 其 他 参数 之 前 先 指 定 ParameterDirection 为 
ReturnValue 的 参数 。 


[c#] 

SqlConnection nwindConn=new SqlConnection ("Data Source= localhost;Integrated Security= 
SSPI;"+"Initial Catalog=northwind"); 

SqlDataAdapter catDA= new SqlDataAdapter ("SELECT CategoryID, CategoryName FROM Catego- 
ries", nwindConn); 

catDA. InsertCommand= new SqlCommand ("InsertCategory", nwindConn); 
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catDA. InsertCommand.CommandType= CommandType.StoredProcedure; 

SqlParameter myParm= catDA. InsertCommand.Parameters.Add ("@ RowCount", SqlDbType.Int); 
myParm.Direction=ParameterDirection.ReturnValue; 

CatDA. InsertCommand. Parameters. Rdd ("@ CategoryName", SqlDbType. NChar, 15, "Catego- 
ryName"); 

myParm= catDA. InsertCommand. Parameters. Add ("@ Identity", SqlDbType.Int, 0, "Category- 
ID"); 

myParm.Direction=ParameterDirection.Output; 

DataSet catDS=new DataSet (); 

CatDA.Fill]l (catDS, "Categories"); 

DataRow newRow= catDS.Tables["Categories"] .NewRow(); 

newRow["CategoryName"]= "New Category"; 

catDS.Tables ["Categories"] .Rows.Add (newRow); 

CatDA.Update (catDS, "Categories"); 

Int32 rowCount= (Int32)catDA.InsertCommand.Parameters["@ RowCount"] .Value; 


4.3.4 DataReader 对 象 


1. 使 用 DataReader 检索 数据 

可 以 使 用 ADO. NET DataReader 从 数据 库 中 检索 只 读 、 只 进 的 数据 流 。 查 询 结 果 在 
查询 执行 时 返回 ,并 存储 在 客户 端的 网 络 缓冲 区 中 ,直到 用 户 使 用 DataReader 的 Read 方 
法 对 它们 发 出 请 求 。 使 用 DataReader 可 以 提高 应 用 程序 的 性 能 ,因为 一 旦 数据 可 用 ,Da- 
taReader 方法 就 立即 检索 该 数据 ,而 不 是 等 待 返回 查询 的 全 部 结果 。 并 且 在 默认 情况 
下 ,该 方法 一 次 只 在 内 存 中 存储 一 行 ,从 而 降低 了 系统 开销 。 

当 创 建 Command 对 象 的 实例 后 ,可 调用 Command. ExecuteReader 从 数据 源 中 检索 
行 , 从 而 创建 一 个 DataReader, 如 以 下 示例 所 示 : 


[C#] 
SqlDataReader myReader=myCommand.ExecuteReader (); 


使 用 DataReader 对 象 的 Read 方法 可 从 查询 结果 中 获取 行 。 通 过 向 DataReader 传 
递 列 的 名 称 或 序号 引用 ,可 以 访问 返回 行 的 每 一 列 。 不 过 ,为 了 实现 最 佳 性 能 ,DataRead- 
er 提供 了 一 系列 方法 ,它们 将 使 用 户 能 够 访问 其 本 机 数据 类 型 (GetDateTime、GetDou- 
ble、GetGuid 和 GetInt32 等 ) 形 式 的 列 值 。 在 基础 数据 类 型 为 已 知 时 ,如 果 使 用 类 型 化 访 
问 器 方法 ,将 减少 在 检索 列 值 时 所 需 的 类 型 转换 量 。 

注意 : . NET Framework 1. 1 版 包含 DataReader 的 附加 属性 HasRows, 该 属性 使 
用 户 在 读 取 DataReader 之 前 就 可 确定 它 是 否 返回 了 任何 结果 。 

以 下 代码 示例 循环 访问 一 个 DataReader 对 象 . 并 从 每 个 行 中 返回 两 个 列 。 
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DataReader 提供 未 缓冲 的 数据 流 , 该 数据 流 使 过 程 逻 辑 可 以 有 效 地 按 顺 序 处 理 从 数 
据 源 中 返回 的 结果 。 由 于 数据 不 在 内 存 中 缓存 ,所 以 在 检索 大 量 数据 时 ,DataReader 是 
一 种 适合 的 选择 。 

2. 关闭 DataReader 

每 次 使 用 完 DataReader 对 象 后 都 应 调用 Close 方法 。 

如 果 Command 包含 输出 参数 或 返回 值 .那么 在 DataReader 关闭 之 前 ,将 无 法 访问 
这 些 输 出 参数 或 返回 值 。 

注意 ; 当 DataReader 打开 时 ,该 DataReader 将 以 独占 方式 使 用 Connection。 在 初始 
DataReader 关闭 之 前 ,将 无 法 对 Connection 执行 任何 命令 (包括 创建 另 一 个 DataRead- 
ws 

不 要 在 类 的 Finalize 方法 中 对 Connection、DataReader 或 任何 其 他 托管 对 象 调用 
Close 或 Dispose。 在 终结 器 中 , 仅 释 放 类 直接 拥有 的 非 托管 资源 。 如 果 类 不 拥有 任何 非 
托管 资源 , 则 不 要 在 类 定义 中 包含 Finalize 方法 。 

3. 多 个 结果 集 

如 果 返 回 的 是 多 个 结果 集 ,DataReader 会 提供 NextResult 方法 来 按 顺 序 循 环 访问 这 
些 结果 集 , 如 以 下 代码 示例 所 示 : 
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4. 从 DataReader 中 获取 架构 信息 

当 DataReader 打开 时 ,可 以 使 用 GetSchemaTable 方法 检索 有 关 当 前 结果 集 的 架构 
信息 。GetSchemaTable 将 返回 一 个 填充 了 行 和 列 的 DataTable 对 象 .这 些 行 和 列 包含 当 
前 结果 集 的 架构 信息 。 对 于 结果 集 的 每 一 列 ,DataTable 都 将 包含 一 行 。 架 构 表 行 的 每 
一 列 都 映射 到 在 结果 集中 返回 的 列 的 属性 ,其 中 ColumnName 是 属性 的 名 称 , 而 列 的 值 
为 属性 的 值 。 以 下 代码 示例 为 DataReader 写 出 架构 信息 。 


5. SqlDataReader 类 

提供 一 种 从 数据 库 读 取 只 进 的 行 流 的 一 种 方式 。 无 法 继承 此 类 。 

以 下 示例 创建 一 个 SqlConnection .一 个 SqlConnection 和 一 个 SqlDataReader。 该 示 
例 读 取 全 部 数据 ,并 将 这 些 数据 写 到 控制 台 。 最 后 ,该 示例 先 关 闭 SqlDataReader, 然 后 关 
闭 SqlConnection 。 


通过 本 章 的 学 习 , 读 者 应 该 能 够 通过 ADO. NET 访问 各 种 数据 库 , 能 够 对 数据 库 进 
行 增 \ 删 . 查 和 改 等 操作 ,能够 在 ADO. NET 中 调用 存储 过 程 。 
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5.1 系统 规划 与 设计 


前 面 几 章 讲述 了 网 站 建设 的 基本 知识 。 作 为 这 些 知识 的 综合 应 用 ,本 章 将 介绍 一 个 
具体 的 实例 一 一 远程 教育 系统 。 现 代 远 程 教育 的 发 展 已 经 成 为 全 球 性 的 大 趋势 ,远程 开 
放 教 育成 为 各 级 各 类 学 校 的 一 种 重要 教育 手段 ,实施 远程 开放 教育 的 大 学 继续 在 扩大 规 
模 、 提 高 质量 上 发 挥 作 用 ,并 将 成 为 终身 教育 和 学 习 化 社会 的 重要 组 成 部 分 。 这 里 所 涉及 
的 远程 教育 系统 的 实例 ,具体 的 介绍 如 下 。 


5.1.1 系统 平台 


在 进行 系统 设计 之 前 ,首先 明确 一 下 系统 开发 平台 和 应 用 平台 。 
开发 平台 如 下 。 

(1) Microsoft Visual Studio. Net2005 ,使 用 C# 语言。 

(2) Microsoft IIS 6. 0。 

(3) Microsoft SQL Server 2000 。 

应 用 平台 如 下 。 

(1) Microsoft . NET Framework 。 

(2) Microsoft IIS 6.0。 

(3) Microsoft SQL Server 2000。 


5.1.2 系统 功能 概述 


我 们 要 实现 的 是 一 个 具有 基本 功能 的 远程 教育 系统 。 那 么 对 于 一 个 典型 的 远程 教育 
系统 来 说 ,都 有 哪些 基本 的 功能 呢 ? 

首先 进入 网 站 首页 ,上 面 有 多 个 栏目 ,文章 按 栏目 分 类 。 前 台 提 供 的 主要 功能 如 下 。 

(1) 以 各 种 角色 (管理 员 .教师 和 学 员 ) 登 录 进 入 管理 平台 的 登录 窗口 。 

(2) 学 习 简报 栏目 。 

(3) 答疑 解 惑 栏目 。 

(4) 友情 链接 栏目 。 
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(5) 系统 简介 栏目 。 
(6) 培训 公告 栏目 。 
(7) 作业 展示 栏目 。 
(8) 思考 习题 栏目 。 
(9) 导航 栏 中 的 系统 主页 .系统 简介 ,培训 公告 .学 习 简 报 , 答 疑 解 惑 , 作 业 展 示 、 思 考 
习题 和 友情 链接 等 二 级 页 面 的 链接 。 
对 于 各 个 栏目 ,由 栏目 首页 、 含 栏目 相关 文章 标题 列表 等 页 面 组 成 , 单 击 标题 可 以 查 
看 到 文章 的 相关 内 容 。 文 章 详细 内 容 显 示 页 面 将 显示 相应 文章 的 标题 ,作者 、 发 表 时 间 、 
文章 正文 等 内 容 。 
后 台 提 供 的 功能 ,如 表 5-1 所 示 。 


表 5-1 角色 及 对 应 的 功能 


角 色 功 能 

管理 员 系统 简介 管理 ,培训 公告 管理 ,学 习 简报 管理 ,答疑 解 惑 管理 ,课程 管理 ,友情 
链接 管理 ,用 户 管理 ,个 人 信息 设置 ,退出 

教师 作业 展示 管理 ,思考 习题 管理 ,个 人 信息 设置 ,退出 

学 员 作业 展示 管理 ,思考 习题 管理 ,个 人 信息 设置 ,退出 


以 上 是 对 系统 进行 简单 的 介绍 ,在 接 下 来 的 章节 中 将 进行 详细 讲述 。 
系统 模块 划分 与 流程 
根据 上 面 的 功能 列表 ,可 归纳 出 系统 的 模块 划分 ,如 表 5-2 所 示 。 


5. 


序号 


1:3 


功能 模块 类 别 


表 5-2 模块 功能 列表 
功能 模块 


备 注 


1 


系统 类 
(对 常用 功能 的 封装 ) 


基础 数据 连接 类 


提供 对 数据 库 连 接 的 支持 


基础 数据 操作 类 


提供 对 数据 操作 的 支持 


业务 数据 操作 类 


提供 对 具体 业务 数据 操作 的 支持 


浏览 者 (前 台 用 户 ) 


首页 模块 


栏目 页 模块 


文章 浏览 模块 


登录 模块 


系统 简介 管理 模块 


培训 公告 管理 模块 


管理 员 ( 后 台 用 户 ) 


学 习 简报 管理 模块 


答疑 解 惑 管理 模块 
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续 表 
序号 功能 模块 类 别 功能 模块 备 注 

12 课程 管理 模块 

13 We 友情 链接 管理 模块 
14 用 户 管理 模块 

15 个 人 信息 设置 模块 
16 作业 展示 管理 模块 
17 教师 (后 台 用 户 ) 思考 习题 管理 模块 
18 个 人 信息 设置 模块 
19 作业 展示 管理 模块 
20 学 员 ( 后 台 用 户 ) 思考 习题 管理 模块 
21 个 人 信息 设置 模块 


可 以 看 到 ,需求 一 步 一 步 地 明确 了 。 下 面 为 了 更 清晰 地 表现 出 需求 的 细节 ,将 根据 功 
能 概述 和 模块 划分 , 画 出 系统 流程 图 。 首 先 画 出 大 功能 类 别 的 流程 图 。 

图 5-1 所 示 为 前 台 用 户 模块 流程 图 ,图 5-2 所 示 为 管理 员 模 块 流程 图 ,图 5-3 所 示 为 
教师 模块 流程 图 ,图 5-4 所 示 为 学 员 模块 流程 图 。 


用 户 进 入 
浏览 


管理 员 进入 
管理 平台 


浏览 方式 


选择 栏目 


在 栏目 中 
选择 文章 


系 |[ 答 
等 | 各 
介 ]| 恕 
管 | 答 
理 上 | 理 


将 文章 内 容 按照 预先 的 
组 织 形式 展现 给 浏览 者 


图 5-1 前 台 用 户 模块 流程 图 
图 5-2 管理 员 模 块 流程 图 


以 上 就 是 系统 4 大 模块 的 整体 流程 。 下 一 节 将 进一步 对 功能 进行 细 化 。 
5.1.4 系统 功能 设计 与 列表 


此 节 将 进入 到 详细 设计 阶段 。 根 据 5. 1. 3 节 中 流程 图 和 模块 的 分 析 及 划分 结果 ,在 
这 一 节 将 把 每 个 模块 的 详细 功能 以 表 的 形式 列 出 来 ,将 各 个 模块 之 间 的 结构 关系 整理 清 
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学 生 进 入 
管理 平台 


出 错 提示 


作业 思考 个 人 作业 
展示 管理 习题 管理 信息 管理 展示 管理 管 
1 


图 5-3 教师 模块 流程 图 图 5-4 学 员 模 块 流程 图 


楚 , 这 将 为 后 面 章 节 中 的 编码 阶段 打下 良好 的 基础 。 表 5-2 所 示 共 有 18 个 模块 ,前 台 
4 个 模块 ,后 台 14 个 模块 。 下 面 开始 详细 描述 模块 功能 和 流程 (如 表 5-3 一 表 5-20 所 示 )。 
表 5-3 首页 模块 功能 
序号 功能 列表 功能 明细 备注 

1 学 习 简 报 ”| 按 发 布 学 习 简 报 的 时 间 排 序 取 最 新 的 4 篇 学 习 简报 
2 答疑 解 惑 | 按 发 布 答疑 解 惑 的 时 间 排 序 取 最 新 的 4 篇 答疑 解 惑 
， 友情 链接 | 按 建立 友情 链接 的 时 间 排 序 取 最 新 的 4 个 友情 链接 
4 系统 简介 “| 对 系统 的 简单 介绍 , 按 规定 显示 字 的 个 数 
5 
6 
六 


培训 公告 “| 按 发 布 培 训 公 告 的 时 间 排 序 取 最 新 的 5 篇 培训 公告 
作业 展示 “| 按 学 生 作业 的 分 数 排序 取 分 数 最 高 的 5 篇 作业 答卷 
思考 习题 | 按 学 生 思考 习题 的 分 数 排序 取 分 数 最 高 的 5 篇 思考 习题 答卷 


首页 模块 实际 上 只 有 1 个 页 面 , 上 面 进行 的 是 栏目 的 划分 。 
表 5-4 栏目 页 模块 功能 


序号 功能 列表 功能 明细 备注 
1 学 习 简报 列表 pa 
2 管 疑 解 惑 列表 Pl ent i 
3 友情 链接 列表 a 
a 系统 简介 主页 pint gilt adi rd 


单 击 “ 更 多 ”时 进入 培训 公告 列表 ,按照 时 间 排 序列 出 了 
所 有 的 培训 公告 
单 击 * 更 多 ”时 进入 作业 展示 列表 ,按照 分 数 排序 列 出 了 
所 有 的 作业 展示 
单 击 “更 多 ”时 进入 思考 习题 列表 ,按照 分 数 排 序列 出 了 
所 有 的 思考 习题 


5 培训 公告 列表 


6 作业 展示 列表 


,3 思考 习题 列表 
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栏目 页 模块 有 7 个 页 面 ,每 个 栏目 1 个 页 面 。 


表 5-5 文章 浏览 模块 功能 


序号 功能 列表 功能 明细 备注 
- | 文章 的 详细 内 容 显示 ,包括 标题 .发布 者 、 发 布 时 间 
1 。 | 学 习 简报 内 容 显示 | 大正 久生 
| 文章 的 详细 内 容 显示 ,包括 标题 .发布 者 ` 发 布 时 间 
2 。 | 知 颖 解 下 内 容 显示 | 大 下 人 和 
Er 文章 的 主 细 内 容 旺 未, 包括 标 是 发布 者、 从 布 时 间 
| 文章 的 详细 内 容 显示 ,包括 作业 标题 .学 号 \ 姓 名 \ 作 
4 | 作业 展示 内 容 显示 | 业 要 求 , 作 业内 容 、. 教 师 评语 和 得 分 竺 
-| 文章 的 详细 内 容 显示 ,包括 习题 标题 .学 号 .姓名 习 
5 。 | 思考 习题 内 容 显示 | 题 要 求 习 题 内 容 、 教 师 评语 和 得 分 等 
文章 页 模块 实际 上 有 5 个 页 面 ,不 同 栏目 的 文章 用 不 同 的 页 面 显示 。 
表 5-6 登录 模块 功能 
序号 功能 列表 功能 明细 备注 
1 登录 通过 选择 角色 ,输入 用 户 名 和 密码 登录 到 管理 平台 
2 注册 新 用 户 注册 个 人 信息 (只 限于 学 员 注 册 ) 
3 找 回 密码 | 用 户 可 以 通过 输入 真实 姓名 和 身份 证 号 码 找 回 密 码 
表 5-7 系统 简介 管理 模块 (管理 员 ) 功 能 
序号 功能 列表 功能 明细 备注 
如 果 数 据 库 中 没有 系统 简介 的 内 容 ,管理 员 可 以 发 布 新 
发 布 系统 简介 | 的 系统 简介 的 内 容 
2 | 修改 系统 简介 | 管理 员 可 以 对 原 有 的 系统 简介 的 内 容 进行 修改 
3 | 删除 系统 简介 | 管理 员 可 以 删除 原 有 的 系统 简介 的 内 容 
表 5-8 培训 公告 管理 模块 (管理 员 ) 功 能 
序号 功能 列表 功能 明细 备注 
1 | 新 增 培 训 公 告 管理 员 可 以 增加 新 的 培训 公告 
2 | 修改 培训 公告 管理 员 可 以 修改 原 有 的 培训 公告 
3 | 删除 培训 公告 管理 员 可 以 删除 原 有 的 培训 公告 
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表 5-9 学 习 简 报 管理 模块 (管理 员 ) 功 能 


序号 功能 列表 功能 明细 备注 
1 新 增 学 习 简 报 管理 员 可 以 增加 新 的 学 习 简报 
时 修改 学 习 简报 管理 员 可 以 修改 原 有 的 学 习 简 报 
3 删除 学 习 简报 管理 员 可 以 删除 原 有 的 学 习 简报 
表 5-10 答疑 解 惑 管理 模块 (管理 员 ) 功 能 
序号 功能 列表 功能 明细 备注 
1 新 增 答疑 解 惑 管理 员 可 以 增加 新 的 答疑 解 惑 
2 修改 答疑 解 惑 管理 员 可 以 修改 原 有 的 答疑 解 惑 
3 删除 答疑 解 惑 管理 员 可 以 删除 原 有 的 答疑 解 惑 
表 5-11 课程 管理 模块 (管理 员 ) 功 能 
序号 功能 列表 功能 明细 备注 
管理 员 通过 输入 课程 的 名 称 可 以 查询 到 该 课程 的 任课 教 
1 查询 师 。 如 果 不 输入 课程 名 称 , 默 认 的 是 查询 所 有 课程 的 名 
称 及 任课 教师 
委 新 增 课程 管理 员 可 以 新 增加 课程 
3 修改 管理 员 可 以 修改 课程 名 称 及 任课 教师 
4 删除 管理 员 可 以 删除 课程 名 称 和 任课 教师 
表 5-12 ”友情 链接 管理 模块 (管理 员 ) 功 能 
序号 功能 列表 功能 明细 备注 
和 新 增 链接 管理 员 可 以 增加 新 的 链接 
2 修改 链接 管理 员 可 以 修改 原 有 的 链接 
3 删除 链接 管理 员 可 以 删除 原 有 的 链接 
表 5-13 用户 管 理 模块 (管理 员 ) 功 能 
序号 功能 列表 功能 明细 备注 
管理 员 可 以 通过 输入 用 户 名 查询 到 该 用 户 的 基本 情况 
1 查询 (密码 和 角色 名 称 ) ,如 果 不 输入 用 户 名 ,默认 的 是 查询 所 
有 用 户 的 基本 情况 
2 新 增 用 户 管理 员 可 以 增加 新 的 用 户 ( 管 理 员 和 教师 ) 


删除 


管理 员 可 以 删除 用 户 
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表 5-14 个 人 信息 设置 (管理 员 ) 功 能 


系统 功能 的 扩充 是 系统 开发 中 非常 重要 的 一 个 环节 ,因为 在 当前 现实 的 项 目 开 发 中 ， 


序号 功能 列表 功能 明细 备注 
1 设置 个 人 信息 设置 管理 员 自 己 的 个 人 信息 
表 5-15 ”作业 展示 管理 (教师 ) 功 能 
序号 功能 列表 功能 明细 备注 
教师 选择 课程 以 后 ,可 查询 到 自己 发 布 的 关于 该 课程 的 
1 查询 作业 作业 ,可 以 修改 和 删除 该 作业 , 单 击 作 业 的 标题 可 以 查看 
到 学 生 做 该 作业 的 情况 
2 新 增 作业 教师 可 以 增加 新 的 作业 
表 5-16 思考 习题 管理 (教师 ) 功 能 
序号 功能 列表 功能 明细 备注 
教师 选择 课程 以 后 ,可 查询 到 自己 发 布 的 关于 该 课程 的 
1 查询 思考 习题 | 习题 ,可 以 修改 和 删除 该 习题 , 单 击 习题 的 标题 可 以 查看 
到 学 生 做 该 习题 的 情况 
2 新 增 思考 习题 | 教师 可 以 增加 新 的 习题 
表 5-17 个 人 信息 设置 (教师 ) 功 能 
序号 功能 列表 功能 明细 备注 
1 设置 个 人 信息 设置 教师 自己 的 个 人 信息 
表 5-18 ”作业 展示 管理 (学 员 ) 功 能 
序号 功能 列表 功能 明细 备注 
1 查询 作业 学 员 可 以 按照 教师 或 者 课程 两 个 查询 条 件 进 行 查询 , 单 
击 作业 的 名 称 可 以 查看 到 该 作业 ,并 且 可 以 回答 作业 
表 5-19 思考 习题 管理 (学 员 ) 功 能 
序号 功能 列表 功能 明细 备注 
1 查询 习题 学 员 可 以 按照 教师 或 者 课程 两 个 查询 条 件 进行 查询 , 单 
击 习 题 的 名 称 可 以 查看 到 该 习题 ,并 且 可 以 回答 习题 
表 5-20 个 人 信息 设置 (学 员 ) 功 能 
序号 功能 列表 功能 明细 备注 
1 设置 个 人 信息 设置 学 员 自 己 的 个 人 信息 
5.1.5 系统 功能 的 扩充 
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几乎 没有 一 个 项 目 开发 一 次 就 满足 所 有 需求 ,后 期 的 系统 升级 是 必需 的 。 所 以 建立 系统 
的 架构 和 设计 系统 的 时 候 , 一 定 要 注意 系统 的 可 扩充 性 .而且 现在 很 多 的 项 目 开发 是 分 期 
进行 的 。 本 书 实例 中 的 一 些 列表 功能 是 给 读者 作为 参考 来 使 用 的 。 

下 一 节 的 数据 设计 ,可 以 说 是 系统 架构 和 扩充 的 重要 基础 , 它 决定 系统 的 许多 关键 
部 件 。 


5.2 数据 库 设 计 


数据 库 设计 是 项 目 开发 中 系统 设计 的 另 一 个 关键 环节 ,在 这 里 之 所 以 要 特别 强调 数 
据 库 设计 的 重要 性 ,是 因为 数据 库 设计 就 像 高 楼 大 厦 的 根基 一 样 ,如 果 设 计 不 好 ,在 后 来 
的 系统 维护 、 变 更 和 功能 扩充 时 ,甚至 于 在 系统 开发 过 程 中 ,将 会 引起 比较 大 的 问题 ,大 量 
的 工作 将 会 重新 进行 。 

下 面 根据 5. 1 节 的 分 析 , 开 始 设计 相关 的 数据 库 。 


5.2.1 数据 库 表 及 表 之 问 的 相互 关系 


基于 上 述 的 详细 设计 ,需要 设计 到 下 列 各 表 , 这 些 表 之 间 相 互 关联 ,共同 存储 着 系统 
所 需 的 数据 。 在 设计 数据 库 表 的 过 程 中 ,可 以 记 住 几 条 原则 ,数据 库 设计 一 个 表 最 好 只 存 
储 一 个 实体 或 对 象 的 相关 信息 ,不同 的 实体 最 好 存储 在 不 同 的 数据 表 中 ,如 果实 体 还 可 以 
再 划分 ,实体 的 划分 原则 是 最 好 能 够 比 当前 系统 开发 的 实体 颗粒 要 小 ;数据 表 的 信息 结构 
一 定 要 合适 , 表 的 字段 数量 一 定 不 要 过 多 ;扩充 信息 和 动态 变化 的 信息 一 定 要 分 开 在 不 同 
的 表 中 ;对 于 出 现 多 对 多 这 样 的 表 关 系 系统 ,尽量 不 出 现 等 。 在 本 系统 中 所 需要 设计 的 数 
据 库 表 如 表 5-21 所 示 。 


表 5-21 数据 库 表 
序号 数据 库 表 数据 库 表 存储 内 容 
| Role 存储 用 户 所 属 的 角色 信息 
六 User 存储 用 户 基本 信息 
3 Column 存储 系统 栏目 信息 
4 Article 存储 文章 信息 
5 Course 存储 课程 信息 
6 HomeWork 存储 作业 和 思考 习题 信息 
7 Answer 存储 学 员 的 答题 信息 
8 FriendshipLink 存储 友情 链接 的 信息 


表 5-21 列 出 了 根据 原则 设计 出 的 系统 所 要 使 用 到 的 数据 库 表 ,并 根据 流程 和 功能 以 
图 的 形式 表示 出 数据 库 各 表 之 间 的 相互 关系 ,具体 如 图 5-5 所 示 。 
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Course 
PK|IDD Article 
Fk CourseName PKE | ID 
TeacherID FKI | UsertD 
FK2| ColumnID 
Title 
Content Column 
PublishTime "| PK|D 
ColumnName 
er Homework 
- ome Wo 
PK|D PK[D 
UserName FKI1| ColumnID 
PassWord 一 FK2| CourseTD 
FKI| RolelD FK3| TeacherID 
RealName Title 
IDCardNumber Content 
Telephone PublishTime 
E-mail 
Answer FriendshipLink 
PK [TID 
Rol FK1| HomeworkID 
FK2| StudentlD 
PK |RolelD AnswerTime 
RoleName Content 
TeacherComment 
HomeworkS 


图 5-5 数据 表 之 间 的 相互 关系 


5.2.2 ”数据库 结构 的 详细 设计 


根据 数据 量 的 大 小 不 同 ,系统 可 以 使 用 不 同 的 数据 库 。 本 系统 使 用 的 是 SQL Server 
2000 数据 库 。SQL Server 数据 库 使 用 方便 ,数据 存储 量 也 比较 大 ,是 比较 适合 中 小 型 网 
站 开发 的 数据 库 。 对 于 大 数据 量 的 网 站 ,可 以 使 用 Oracle 数据 库 。 

远程 教育 系统 的 数据 库 中 各 表 的 设计 结果 如 下 面 几 个 表格 所 示 。 每 个 表格 表示 在 
数据 库 中 的 一 个 表 。 接 下 来 将 根据 设计 的 逻辑 关系 和 目的 逐一 介绍 各 数据 表 的 设计 
思路 。 

1. 角色 表 (Role) 设 计 

此 数据 表 是 系统 的 基础 表 , 系 统 投入 开始 使 用 之 前 ,就 已 经 进行 了 数据 的 初始 化 ,此 
表 的 设计 便于 系统 的 扩展 。 

表 5-22 所 示 为 用 户 角 色 表 ,本 数据 表 的 设计 是 为 了 满足 系统 以 后 功能 的 扩展 需求 ， 
如 果 系 统 需 要 进行 扩展 ,增加 其 他 的 用 户 角 色 , 则 只 需 在 此 表 中 添加 相应 的 角色 名 称 , 配 
置 该 角色 对 应 的 权限 (本 系统 是 通过 XML 配置 角色 的 权限 . 稍 后 章节 会 讲 到 ) ,再 在 用 户 
表 中 增加 对 应 角色 的 用 户 ,就 能 够 实现 系统 的 完美 扩展 。 
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表 5-22 用 户 角 色 表 


序号 字段 含义 字段 名 称 类 型 备 注 
1 角色 编号 RoleID int 主键 , 需 设置 为 自 增长 
2 角色 名 称 RoleName varchar 


表 5-22 中 的 各 字段 说 明 如 下 。 

。 角色 编号 : 是 角色 表 的 主键 ,唯一 表示 一 个 角色 。 

。 角色 名 称 : 是 用 户 所 属 角色 的 名 称 , 如 学 员 ,教师 和 系统 管理 员 等 。 

表 5-22 在 初始 化 时 ,初始 了 如 表 5-23 所 示 的 数据 ,为 方便 系统 投入 运行 后 ,标识 用 


户 所 属 的 角色 。 
表 5-23 用 户 角色 表 初 始 化 数据 
角色 编号 (RoleID) 角色 名 称 (RoleName) 
1 系统 管理 员 
2 教师 
3 学 员 


2. 用 户 表 (User) 设 计 
表 5-24 所 示 为 User 用 户 表 , 用 于 存放 系统 的 用 户 信息 。 由 于 用 户 表 中 字段 较 多 , 且 
大 多 数 是 用 户 的 个 人 信息 ,所 以 表 5-24 只 是 列 出 了 常用 的 字段 及 与 其 他 表 有 关联 的 


表 5-24 用 户 表 
序号 字段 含义 字段 名 称 类 型 备 注 
用 户 编号 ID int 主键 , 需 设置 为 自 增长 
2 用 户 名 UserName varchar 作为 用 户 登 录用 
3 密码 PassWord varchar 
4 角色 编号 RoleID int 与 角色 表 关联 
5 真实 姓名 RealName varchar 
6 身份 证 号 IDCardNumber varchar 
7 联系 电话 Telephone varchar 
8 电子 邮件 E-mail varchar 


表 5-24 中 的 各 字段 说 明 如 下 。 

。 用 户 编号 (ID) : 是 用 户 表 的 主键 ,唯一 标识 一 个 用 户 ,在 其 他 表 中 都 需要 关联 它 ， 
例如 课程 表 (course) 就 要 使 用 教师 编号 (TeacherID) 来 建立 课程 与 教师 的 关联 ， 
表明 课程 是 由 哪 位 教师 负责 。 这 里 的 教师 编号 就 是 所 有 用 户 编 号 中 的 一 个 ,只 是 
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名 字 不 同 而 已 。 
用 户 名 和 密码 : 是 必需 的 ,作为 用 户 登 录 的 入 口 ,其 中 用 户 名 要 求 是 唯一 的 , 即 在 
数据 库 表 里 是 互 不 相同 的 。 
角色 编号 : 是 角色 表 的 外 键 ,在 这 里 是 为 了 表明 用 户 的 身份 ,明确 用 户 属于 哪 类 
角色 , 它 指向 角色 表 的 编号 字段 。 
真实 姓名 、 身 份 证 号 、 联 系 电话 、 电 子 邮 件 ,还 有 没有 列举 出 来 的 字段 如 性 别 、 地 址 
等 ,都 是 作为 用 户 信息 的 一 个 最 基本 的 属性 。 其 中 ,身份 证 号 还 有 另外 一 个 作用 ， 
就 是 当 用户 忘 了 密码 时 ,可 以 通过 出 示 身 份 证 号 获取 丢失 的 密码 。 

根据 系统 的 要 求 ,管理 员 不 能 通过 注册 取得 ,所 以 在 系统 投入 使 用 之 前 ,用 户 表 初始 
化 了 一 条 系统 管理 员 的 记录 ,用 户 名 和 密码 都 是 adtmin, 其 他 信息 由 管理 员 登 录 后 在 后 台 
自己 填写 ,密码 也 由 管理 员 在 以 后 的 使 用 中 自己 修改 。 

3. 栏目 表 (Column) 设 计 

表 5-25 所 示 为 栏目 表 , 记 录 着 系统 的 栏目 信息 。 栏 目 表 主要 有 两 个 作用 ,一 是 为 了 
防止 完 余 ,因为 在 一 般 情 况 下 ,在 文章 表 (Article) 中 ,每 篇 文章 都 应 该 标明 属于 哪个 栏目 ， 
往往 需要 加 上 栏目 名 称 的 字段 。 当 系统 运行 时 间 长 了 以 后 ,文章 的 数量 就 会 增加 ,导致 存 
储 的 栏目 信息 过 多 , 且 元 余 量 大 ,所 以 在 远程 教育 系统 中 把 栏目 单独 抽出 来 作为 一 张 表 ， 
而 仅 用 栏目 编号 与 文章 表 关联 ,就 可 以 很 好 地 解决 这 个 问题 。 二 是 为 了 满足 以 后 系统 扩 
展 , 当 需 要 修改 栏目 或 者 新 增 其 他 的 栏目 时 ,只 需 在 栏目 表 修 改 即 可 。 


表 5-25 栏目 表 
序号 字段 含义 字段 名 称 类 型 备 注 
1 栏目 编号 ID int 主 码 , 需 设置 为 自 增长 
2 栏目 名 称 ColumnName varchar 


表 5-25 中 的 各 字段 说 明 如 下 。 
。 栏目 编号 (ID): 是 表 的 主键 ,唯一 标识 一 个 栏目 ; 
。 栏目 名 称 (ColumnName): 是 栏目 的 名 称 。 
栏目 信息 表 也 是 系统 的 基础 表 , 在 系统 投入 使 用 之 前 就 已 经 进行 了 数据 的 初始 化 ,如 
表 5-26 所 示 。 
表 5-26 栏目 表 初 始 化 数据 


栏目 编号 (ID) 栏目 名 称 (ColumnName) 栏目 编号 (ID) 栏目 名 称 (ColumnName) 
系统 简介 5 作业 展示 
2 培训 公告 6 思考 习题 
3 学 习 简 报 x 答疑 解 惑 
4 友情 链接 


4. 文章 表 (Article) 设 计 
表 5-27 所 示 为 文章 表 ,. 首 页 中 系统 简介 .培训 公告 .学习 简 报 和 答疑 解 惑 栏目 的 文章 
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信息 都 存放 在 该 表 中 。 由 上 面 的 逻辑 结构 可 知 ,文章 与 发 表 人 的 关系 为 多 对 一 ,也 就 是 说 
一 篇 文章 只 能 由 某 个 人 发 表 . 一 个 人 可 以 发 表 多 篇 文章 。 文 章 与 栏目 的 关系 也 是 多 对 一 
的 关系 ,也 就 是 一 篇 文章 只 能 属于 某 个 栏目 ,一 个 栏目 可 以 包含 多 篇 文章 。 


表 5-27 文章 表 Article 


序号 字段 含义 字段 名 称 类 型 备 注 
1 文章 编号 ID int 主键 , 需 设置 为 自 增长 
2 用 户 编号 UserID int 与 用 户 表 关 联 
3 栏目 编号 ColumnID int 与 栏目 表 关 联 
4 文章 标题 Title varchar 
5 文章 内 容 Content varchar 
6 发 表 时 间 PublishTime datetime 


表 5-27 中 的 各 字段 说 明 如 下 。 
文章 编号 (ID) : 为 文章 表 的 主键 ,唯一 标识 一 篇 文章 。 


用 户 编号 (UserID): 为 用 户 表 的 外 键 ,指向 用 户 表 的 编号 字段 ,表明 文章 是 谁 发 
布 的。 只 有 管理 员 有 发 表 文章 的 权限 。 
栏目 编号 (ColumnID): 为 栏目 表 的 外 键 ,指向 栏目 表 的 编号 字段 ,表明 文章 属于 


文章 标题 (Title) ,文章 内 容 (CContent) 和 发 表 时 间 (PublishTime) 是 文章 的 基本 


哪个 栏目 。 
5. 课程 表 (Course) 的 设计 


表 5-28 所 示 为 课程 表 , 记 录 着 系统 中 所 有 课程 的 信息 。 巾 上 面 的 逻辑 结构 可 知 , 课 
程 与 教师 的 关系 为 多 对 一 ,也 就 是 说 一 门 课程 只 能 由 某 个 教师 负责 ,一 个 教师 可 以 负责 多 


门 课程 。 
表 5-28 课程 表 Course 
序号 字段 含义 字段 名 称 类 型 备 注 
和 课程 编号 ID int 主键 , 需 设 置 为 自 增长 
2 课程 名 称 CourseName varchar 
3 教师 编号 TeacherID int 与 用 户 表 关 联 


表 5-28 中 的 各 字段 说 明 如 下 。 
。 课程 编号 (ID) : 为 课程 表 的 主键 ,唯一 标识 一 门 课程 。 
。 课程 名 称 (CourseName) : 为 课程 的 名 字 ,该 字段 的 宽度 是 50, 创 建 时 ,应 控制 课 


程 名 称 的 长 度 。 


"教师 编号 (TeacherID): 为 用 户 表 的 外 键 ,指向 用 户 表 的 编号 字段 。 任 课 教师 具 


有 操作 该 课程 的 权限 。 


6. 
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习题 表 (HomeWork) 的 设计 


表 5-29 所 示 为 习题 表 , 记 录 着 教师 发 布 的 作业 和 思考 习题 的 相关 信息 。 由 逻辑 结构 可 
知 ,习题 与 栏目 是 多 对 一 的 关系 ,习题 与 课程 是 多 对 一 的 关系 ,习题 与 教师 也 是 多 对 一 的 关系 。 


表 5-29 习题 表 HomeWork 


序号 字段 含义 字段 名 称 类 型 备 注 
1 习题 编号 ID int 主键 , 需 设置 为 自 增长 
2 栏目 编号 ColumnID int 与 栏目 表 关 联 
3 课程 编号 CourseID int 与 课程 表 关联 
4 教师 编号 TeacherID int 与 用 户 表 关 联 
5 习题 题目 Title varchar 
6 习题 内 容 Content varchar 
发 表 时 间 PublishTime datetime 


表 5-29 中 的 各 字段 说 明 如 下 。 


7. 


习题 编号 (ID) : 为 习题 表 的 主键 ,唯一 标识 一 道 习 题 。 

栏目 编号 (ColumnID) : 为 习题 所 属 的 栏目 ,是 栏目 表 的 外 键 。 在 该 系统 中 , 值 只 
可 能 为 作业 和 思考 习题 栏目 编号 。 

课程 编号 (CourseID) : 为 习题 所 属 的 课程 ,是 课程 表 的 外 键 ,指向 课程 表 中 课程 
编号 。 

教师 编号 (TeacherID): 为 用 户 表 的 外 键 , 指 向 用 户 表 的 编号 字段 ,表明 习题 是 由 
谁 发 布 的 ( 注 : 根据 前 面 的 分 析 ,课程 与 教师 是 多 对 一 的 关系 ,也 就 是 说 一 门 课程 
只 能 由 一 个 教师 负责 ,由 此 可 知 ,习题 所 属 的 课程 确定 了 ,教师 也 就 确定 了 。 所 以 
在 该 表 中 ,教师 编号 为 宛 余 字 段 。 但 考虑 到 性 能 因素 ,加 上 了 该 字段 )。 

习题 题目 (Title) .习题 内 容 (CContent) 和 发 表 时 间 (PublishTime) 为 习题 的 基本 
信息 。 


答题 信息 表 (Answer) 的 设计 


表 5-30 所 示 为 答题 信息 表 , 记 录 着 学 员 答 题 的 相关 信息 。 该 表 关 系 比较 复杂 ,一 方 
面 是 学 员 答 题 的 内 容 , 另 一 方面 是 教师 批改 的 相关 信息 ,这 两 方面 不 是 同时 进行 的 。 只 有 
学 员 先 做 作业 或 者 做 思考 习题 ,提交 后 ,教师 才能 批改 。 


表 5-30 答题 信息 表 Answer 


序号 字段 含义 字段 名 称 类 型 备 注 
1 答题 编号 ID int 主键 , 需 设置 为 自 增长 
2 习题 编号 HomeworkID int 与 习题 表 关联 
3 学 员 编 号 StudentID int 与 用 户 表 关联 
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续 表 
序号 字段 含义 字段 名 称 类 型 备 注 
4 答题 时 间 AnswerTime datetime 
5 答题 内 容 Content varchar 
6 教师 评语 TeacherComment varchar 
7 教师 评分 HomeworkS float 


表 5-30 中 的 各 字段 说 明 如 下 。 
。 答题 编号 (ID) : 为 答题 表 的 主键 ,唯一 标识 一 次 答题 信息 。 

。 习题 编号 (HomeworkID) : 为 所 答 习 题 编号 ,是 习题 表 的 外 键 。 

。 学 员 编号 (StudentID) : 为 回答 习题 的 学 员 ,是 用 户 表 的 外 键 ,指向 用 户 表 中 用 户 


编号 。 


。 答题 时 间 (AnswerTime) ,答题 内 容 (Content) 为 答题 的 基本 信息 。 


8. 友情 链接 表 (FriendshipLink) 的 设计 
表 5-31 所 示 为 友情 链接 表 , 记 录 着 友情 链接 的 相关 信息 。 该 表 跟 其 他 表 没 有 关联 ， 


教师 评语 (TeacherComment) .教师 评 分 (HomeworkS) 为 教师 批改 的 相关 信息 。 


由 管理 员 负 责 维护 。 
表 5-31 友情 链接 表 FriendshipLink 
序号 字段 含义 字段 名 称 类 型 备 注 
1 链接 编号 ID int 主键 , 需 设 置 为 自 增 长 
2 链接 名 称 LinkTitle varchar 
3 链接 地 址 LinkUrl varchar 
4 添加 时 间 AddTime datetime 


表 5-31 中 的 各 字段 说 明 如 下 。 
。 链接 编号 (ID) : 为 友情 链接 表 的 主键 ,唯一 标识 一 个 友情 链接 。 
。 链接 名 称 (LinkTitle) 链接 地 址 (LinkUrl) 是 友情 链接 的 基本 信息 。 


。 添加 时 间 (AddTime) : 为 管理 员 添 加 友情 链接 的 时 间 。 


5.3 逻辑 分 层 


这 一 章节 主要 介绍 开发 应 用 程序 时 采用 的 逻辑 分 层 思想 ,以 及 三 层 架 构 在 开发 示例 


中 的 应 用 。 


从 历史 角度 来 说 ,有 两 种 力量 相互 结合 催生 了 逻辑 分 层 方法 。 第 一 种 是 对 可 伸缩 性 


的 需求 。 随 着 Internet 的 发 展 及 Web 为 越 来 越 多 的 最 终 用 户 所 使 用 ,企业 意识 到 他 们 可 
以 将 企业 系统 推 向 个 人 客户 ,将 许多 从 前 由 内 部 系统 (呼叫 中 心 员工 ) 所 做 的 工作 从 公司 
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转移 到 Web 上 。 例 如 ,在 1980 年 ,客户 必须 打 电 话 给 运输 公司 ,来 向 客户 服务 代表 询问 
某 件 包 右 到 了 哪里 。 客 户 服 务 代表 会 询问 跟踪 号 码 , 然 后 使 用 内 部 软件 系统 来 发 现 包 庄 
的 位 置 。 而 到 了 2005 年 ,该 客户 只 需 将 所 选 Web 浏览 器 指向 运输 公司 的 Web 站 点 ,并 
输入 跟踪 号 码 。 使 用 相同 的 后 端 算法 搜索 同一 后 端 数据 存储 系统 ,而 不 同 的 是 ,现在 信息 
直接 由 客户 输入 而 不 是 通过 内 部 员工 间接 输入 。 但 是 .企业 系统 覆盖 范围 的 扩大 势必 伴 
随 着 相应 的 成 本 ,从 前 只 有 几 百 名 用 户 ( 客 户 服务 代表 ) 的 内 部 系统 ,目前 却 拥有 几 十 万 的 
潜在 用 户 (客户 )。 这 时 会 遇 到 一 个 瓶颈 问题 ,大 多 数 数据 库 服务 器 可 以 支持 几 百 个 并 发 
的 连接 ,然而 并 发 连接 如 果 达 到 几 十 万 ,很 快 就 会 使 数据 库 陷 于 瘫痪 。 

但 结果 是 ,人 们 发 现 了 这 些 并 发 连接 的 一 个 有 趣 特性 : 对 于 大 多 数 客户 机 /服务 器 应 
用 环境 而 言 ,针对 数据 库 所 建立 的 连接 大 多 数 时 间 (95% 以 上 ) 都 处 于 空闲 状态 ,来 等 待 要 
针对 数据 库 所 执行 的 请 求 。 也 就 是 说 ,瓶颈 在 于 连接 的 数量 ,而 不 在 于 所 执行 的 任务 。 这 
就 说 明 ,要 增加 数据 库 的 可 伸缩 性 ,需要 以 某 种 方式 增加 通过 这 些 连接 所 完成 的 工作 量 。 
因此 ,要 创建 一 个 过 渡 层 ,客户 机 通过 连接 该 过 渡 层 以 多 工 方式 向 数据 库 传输 请 求 。 简 单 
地 说 ,如 果 数 据 库 只 能 支持 100 个 连接 ,而 每 个 客户 机 连接 被 用 去 1% 的 时 间 , 那 么 可 以 
这 样 来 增加 数据 库 的 可 伸缩 性 : 将 100 个 客户 机 连接 到 中 间 服 务 器 ,这 个 中 间 服 务 器 仅 
使 用 一 个 连接 (总 共 100% 的 时 间 , 每 个 客户 端 占 1%) 来 对 数据 库 进 行 操作 ,可 伸缩 性 则 
增加 了 100 倍 。 

尽管 如 此 ,有 多 少 应 用 环境 真正 需要 这 种 可 伸缩 性 呢 ? 当然 ,在 将 企业 应 用 环境 带 到 
最 终 客 户 群 面前 的 情况 下 ,这 种 可 伸缩 性 可 能 是 必要 的 。 但 许多 应 用 环境 (无 论 是 否 基于 
Web) 仍 然 是 完全 部 署 在 内 部 的 ,这 种 情况 下 只 有 不 到 100( 有 时 少 于 10) 个 客户 机 将 同时 
访问 系统 。 在 内 部 小 用 户 群 应 用 环境 中 还 需要 逻辑 分 层 方法 吗 ? 

这 时 安全 因素 发 挥 了 作用 。 对 于 运行 在 最 终 用 户 计算 机 上 的 应 用 程序 (基于 Web 或 
“ 富 客户 机 ”) ,任何 系统 管理 员 或 安全 顾问 都 不 可 能 推荐 将 包含 关键 任务 数据 的 数据 库 直 
接 放 在 防火 墙 的 后 面 (例如 ,从 在 安全 范围 之 外 运行 的 计算 机 直接 访问 )。 如 果 加 入 一 个 
中 间 计 算 机 并 将 另 一 个 防火 墙 置 于 其 后 ,可 以 创建 通常 称 为 隔离 区 或 DMZ 的 区 域 ,在 其 
中 可 以 进一步 限制 对 数据 库 的 访问 。 这 样 一 个 DMZ 极 大 地 巩固 了 安全 基础 结构 ,降低 
了 成 功 渗透 的 可 能 性 。 这 不 仅 可 以 防止 数据 被 窃取 ,而且 还 有 助 于 保护 服务 器 (及 剩 下 的 
应 用 程序 或 系统 ) 免 受 成 功 的 拒绝 服务 攻击 。 

使 许多 大 型 系统 所 有 者 青睐 逻辑 分 层 系统 的 另 一 个 因素 是 部 署 , 即 物理 地 将 软件 放 
入 客户 机 所 能 访问 的 计算 机 的 过 程 。 在 传统 的 客户 机 /服务 器 环境 中 ,业务 逻辑 与 表现 逻 
辑 和 数据 访问 逻辑 交织 在 一 起 ,使 编程 人 员 感 觉 非常 不 每 服 : 每 次 需要 新 的 更 新 时 (例如 
需要 更 改 企 业 对 数据 的 处 理 方式 或 增加 数据 的 新 视图 ) ,位 于 用 户 桌 面 的 “ 胖 客 户 机 ”就 必 
须 更 换 并 /或 加 入 新 代码 。 这 就 意味 着 ,至 少 在 这 个 时 候 , 有 人 (通常 是 开发 人 员 或 系统 管 
理 员 ,两 者 中 级 别 较 低 的 一 个 ) 需 要 在 各 计算 机 之 间 奔 走 ,来 安装 新 代码 。 或 者 是 要 求 用 
户 从 网 络 下 载 最 新 的 代码 。 当 然 ,大 多 数 的 用 户 不 是 忽略 了 这 一 点 就 是 不 能 正确 操作 。 
这 两 种 情况 都 不 能 使 人 们 对 频繁 发 布 这 种 明智 之 举 真正 产生 信任 。 而 且 部 署 是 需要 时 间 
的 ,在 这 段 时 间 内 ,系统 必须 暂停 工作 ,以 避免 因 混合 版 本 的 应 用 程序 匆忙 操作 数据 库 ,而 
造成 的 任何 类 型 的 语义 数据 损坏 。 
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这 一 部 署 因 素 在 很 大 程度 上 影响 着 人 们 对 逻辑 分 层 模型 ,特别 是 对 基于 Web 的 应 用 
程序 的 青睐 程度 。 现 在 ,人 们 无 需 再 将 代码 部 署 到 各 用 户 桌面 ,而 可 以 将 其 部 署 到 (单个 ) 
Web 服务 器 ,最 终 用 户 的 浏览 器 只 需 去 选取 这 些 更 改 , 而 这 并 不 需要 任何 进一步 的 工作 。 
就 其 本 身 而 言 ,部 署 并 不 是 铺 开 逻辑 分 层 系 统 的 原因 。 在 传统 客户 机 /服务 器 应 用 环境 时 
代 所 无 法 获得 的 一 些 备 选 方案 现在 已 经 加 入 可 能 部 署 方案 清单 中 ,这 其 中 包括 “无 触 式 部 
署 "( 在 .NET 1.x 中 ) 和 ClickOnce( 在 .NET 2.0 中 ), 更 不 用 说 人 们 对 AJAX 和 各 种 混 
合式 结构 日 益 浓厚 的 兴趣 。 事 实 上 ,发 布 能 在 启动 时 进行 自我 更 新 的 富 客户 机 应 用 程序 
(如 在 iTunes 软件 管理 器 .Windows Media Player, 甚 至 是 流行 的 .NET 开发 工具 Re- 
flector 中 所 看 到 的 ) 已 变 得 越 来 越 普遍 。 

采用 逻辑 分 层 的 第 三 个 原因 经 常会 被 人 们 所 提 到 ,但 往往 却 不 能 真正 实现 , 即 中 间 物 
理 层 可 以 成 为 一 些 业务 逻辑 的 集中 点 ,这些 逻 辑 可 以 由 多 个 表现 物理 层 访问 , 却 不 能 为 它 
们 所 知 。 关 于 这 一 点 的 典型 例子 就 是 组 合式 内 联网 /外 联网 应 用 环境 ,其 中 内 部 员工 使 用 
WinForms( 很 快 将 升级 为 Windows Presentation Foundation) 应 用 程序 来 访问 中 间 层 系 
统 , 中 间 层 系统 进而 再 访问 数据 库 , 而 外 部 用 户 ( 合 作 伙 伴 和 /或 客户 ) 使 用 ASP. NET 或 
者 可 能 是 基于 SharePoint 的 Web 站 点 来 进行 同样 的 操作 : 访问 中 间 层 ,中 间 层 进而 再 访 
问 数据 库 。 

软件 设计 逻辑 分 层 在 软件 体系 结构 领域 已 被 普遍 接受 .“ 逻 辑 分 层 " 是 对 软件 的 逻辑 
分 割 , 是 在 开发 人 员 级 对 各 关注 点 的 基础 分 割 ,这样 可 以 更 加 容易 地 划分 系统 的 职责 。 使 
用 逻辑 层 有 助 于 构筑 可 以 分 解 为 子 任务 组 (每 组 子 任务 处 于 某 个 抽象 级 别 ) 的 应 用 程序 。 
换 句 话说 , 它 是 对 各 关注 点 的 典型 分 割 方式 : 将 企业 系统 中 所 涉及 的 各 种 任务 (包括 检索 
数据 ,存储 数据 、 针 对 数据 执行 业务 规则 、 显 示 数 据 和 搜集 输入 值 等 ) 分 割 为 组 件 或 子 节 ， 
以 便 能 够 更 加 轻松 地 跟踪 在 何 时 何 处 发 生 了 什么 。 最 为 常见 的 方式 是 将 任务 分 为 “ 表 
现 ”“ 逻 辑 ”" 和 "数据 访问 "(逻辑 ) 层 。 

而 另 一 方面 “物理 层 " 是 硬件 (通常 是 某 种 形式 的 计算 机 ) 的 物理 分 层 , 系 统 的 一 部 分 
或 全 部 可 以 运行 于 其 上 。 传 统 的 客户 机 /服务 器 计算 ( 即 写 入 可 以 针对 运行 于 单独 服务 器 
上 的 数据 库 执 行 SQL 语句 的 程序 ) 是 一 个 由 两 个 物理 层 构 成 的 系统 。 我 们 每 天 都 享用 
的 万 维 网 也 是 在 两 (物理 ) 层 方法 的 基础 上 构建 的 ,其 中 一 个 物理 层 ( 即 客户 机 ) 位 于 某 人 
的 家 中 或 办 公 室内 ,并 远程 访问 位 于 某 处 服务 器 机 房 中 的 另 一 个 物理 层 。 这 样 的 例子 数 
不 胜 数 。 

相信 大 家 以 前 都 接触 过 开发 软件 时 采用 的 分 层 模 型 。 为 什么 要 使 用 分 层 体系 结构 来 
构建 系统 呢 ? 这 是 人 们 对 于 软件 开发 的 一 种 理念 , 即 当 我 们 面 对 新 项 目 时 往往 将 系统 明 
确 地 分 为 三 个 物理 层次 : 表现 层 . 业 务 逻辑 层 和 数据 访问 或 资源 层 。 

为 什么 要 使 用 分 层 体 系 结构 来 构建 系统 ? 这 是 人 们 对 于 软件 开发 的 一 种 理念 , 即 当 
我 们 面 对 新 项 目 时 往往 将 系统 明确 地 分 为 三 个 物理 层次 : 表现 层 , 用 以 处 理 所 有 用 户 输 
入 和 数据 显示 问题 ;业务 逻辑 层 , 存 放 所 有 “业务 逻辑 ”; 数 据 访问 或 资源 层 , 存 放 用 于 检 
索 、 修 改 或 存储 数据 的 所 有 代码 。 
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5.3.1 三 层 体系 架构 


1. 表示 层 (USL) 

主要 表示 Web 方式 ,也 可 以 表示 成 WinForm 方式 。 基 于 Web 应 用 程序 中 的 “表现 ” 
逻辑 层 是 Web 浏览 器 。 浏览 器 将 要 显示 的 HTML 通常 必须 从 服务 器 内 所 运行 的 某 种 
形式 (ASP 或 ASP. NET) 的 代码 组 件 中 生成 并 被 发 送 给 浏览 器 。 如 果 逻 辑 层 相当 强大 
和 完善 ,无 论 表 现 层 如 何 定 义 和 更 改 , 逻 辑 层 都 能 完善 地 提供 服务 。 

2. 业务 逻辑 层 (BLL) 

主要 是 针对 具体 问题 的 操作 ,也 可 以 理解 成 对 数据 层 的 操作 ,对 数据 业务 逻辑 处 理 。 
“数据 访问 "逻辑 层 用 于 访问 和 处 理 数据 的 命令 ( 即 SQL) 必 须 从 数据 库 层 之 外 被 生成 和 
发 送 。 如 果 说 数据 层 是 积木 , 那 逻 辑 层 就 是 对 这 些 积木 的 搭建 。 

3. 数据 访问 层 (DAL) 

主要 是 对 原始 数据 (数据 库 或 者 文本 文件 等 存放 数据 的 形式 ) 的 操作 层 , 而 不 是 指 原 
始 数据 。 也 就 是 说 ,是 对 数据 的 操作 ,而 不 是 数据 库 , 具 体 为 业务 逻辑 层 或 表示 层 提 供 数 
据 服务 。 


5.3.2 具体 区 分 


(1) 表示 层 : 主要 对 用 户 的 请 求 接受 ,以 及 数据 的 返回 ,为 客户 端 提供 应 用 程序 的 
访问 。 

(2) 业务 逻辑 层 : 主要 负责 对 数据 层 的 操作 ,也 就 是 说 把 一 些 数 据 层 的 操作 进行 
组 合 。 
(3) 数据 访问 层 : 主要 看 数据 层 里 面 有 没有 包含 逻辑 处 理 ,实际 上 它 的 各 个 函数 主 
要 完成 各 个 对 数据 文件 的 操作 ,而 不 必 管 其 他 操作 。 

三 层 结 构 是 一 种 严格 分 层 方法 , 即 数 据 访问 层 只 能 被 业务 逻辑 层 访 问 ,业务 逻辑 层 只 
能 被 表示 层 访问 ,用 户 通过 表示 层 将 请 求 传送 给 业务 逻辑 层 , 业 务 逻 辑 层 完成 相关 业务 规 
则 和 逻辑 ,并 通过 数据 访问 层 访问 数据 库 获 得 数据 ,然后 按照 相反 的 顺序 依次 返回 将 数据 
显示 在 表示 层 。 

当然 ,在 三 层 结构 基础 上 可 以 扩展 成 N 层 ,可 以 作为 了 解 。 对 于 大 多 数 人 来 说 ,N 层 
应 用 程序 就 是 被 分 成 多 个 独立 的 逻辑 部 分 的 应 用 程序 。 最 常见 的 选择 是 分 为 三 个 部 分 : 
表示 、 业 务 逻辑 和 数据 ,当然 还 可 能 存在 其 他 的 划分 方法 。N 层 应 用 程序 最 初 是 为 了 解 
决 与 传统 的 客户 机 /服务 器 应 用 程序 相关 的 问题 而 出 现 的 ,但 是 , 随 着 Web 时 代 的 到 来 ， 
这 一 体系 结构 开始 成 为 新 开发 项 目的 主流 。 

将 应 用 程序 分 解 成 多 个 逻辑 部 分 是 很 有 用 的 。 将 一 个 大 软件 分 成 几 个 小 的 部 分 会 更 
利于 软件 的 构建 .重复 利用 和 修改 ,对 适应 不 同 的 技术 或 不 同 的 业务 组 织 也 很 有 帮助 。 同 
时 ,还 有 一 些 综合 因素 需要 考虑 。 虽 然 模块 化 和 重复 使 用 性 很 有 效 ,但 它们 可 能 会 导致 应 
用 程序 不 能 像 使 用 其 他 方法 那样 安全 、 易 管理 和 快速 。 
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5.3.3 举例 说 明 三 层 结构 的 应 用 


1. 实现 效果 

培训 公告 类 似 于 新 闻 发 布 功 能 ,由 管理 员 在 后 台 增 加 、 删 除 和 修改 。 首 页 显示 内 容 ， 
用 户 单 击 标题 链接 进入 培训 公告 详细 信息 页 面 。 

2. 数据 访问 层 

培训 公告 模块 的 数据 访问 层 为 DAL 文件 夹 下 的 DBAccess. cs、SqlStringFormat. cs 
和 GetSafeData. cs。 该 数据 访问 层 提 供 了 培训 公告 模块 业务 逻辑 层 所 使 用 的 对 培训 公告 


的 增加 、 删 除 和 修改 等 的 方法 。 以 下 是 DBAccess. cs 的 代码 清单 ,如 程序 5-1 所 示 。 
程序 5-1 DBAccess. cs 
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GetDataSet 方法 首先 利用 DBAccess 类 提供 的 Open 方法 创建 了 数据 库 连接 ,然后 创 
建 了 数据 库 命 令 , 并 指定 数据 库 命 令 执 行 SqlString 语句 。 本 方法 的 参数 SqlString ,本 方 
法 返回 dataset 数据 集 ,如 程序 5-2 所 示 。 

程序 5-2 DBAccess. cs 
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增加 新 文章 的 公有 方法 ,将 页 面 上 发 表 的 新 文章 写 到 数据 库 中 ,如 程序 5-3 所 示 。 
程序 5-3 DBAccess. 
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根据 参数 Where 设 定 的 条 件 对 数据 库 中 的 相关 记录 进行 修改 ,在 培训 公告 模块 中 是 
对 培训 公告 文章 的 详细 信息 进行 修改 ,如 程序 5-4 所 示 。 
程序 5-4 DBAccess. cs 
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以 下 是 SqlStringFormat. cs 类 的 代码 清单 ,如 程序 5-5 所 示 。 
程序 5-5 SqlStringFormat. cs 


这 个 类 提供 了 一 个 公有 静态 方法 ,将 参数 pStr 的 文本 转换 成 适合 在 Sql 中 使 用 的 字 
符 串 。 

以 下 是 GetSafeData. cs 类 的 代码 清单 ,如 程序 5-6 所 示 。 

程序 5-6 GetSafeData. 
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这 个 类 提供 了 5 个 公有 静态 方法 ,分 别 从 参数 row 中 安全 地 得 到 列 colname 中 的 值 。 
值 的 类 型 分 别 为 字符 串 类 型 整数 类 型 、. 浮 点 数 类 型 .时 间 类 型 和 布尔 类 型 。 

3. 业务 逻辑 层 

这 一 层 包 括 Article. cs 实体 业务 类 ,提供 了 对 文章 进行 增加 、 删 除 和 修改 的 具体 方 
法 。 还 有 显示 文章 列表 管理 页 面 的 后 台 代码 ,及 增加 文章 页 面 的 后 台 代 码 和 修改 文章 页 
面 的 后 台 代码 。 

以 下 是 Article. cs 类 的 代码 清单 ,如 程序 5-7 所 示 。 

程序 5-7 Article.cs 
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本 类 提供 了 对 文章 进行 增加 、 删 除 和 修改 的 业务 方法 。 由 该 层 提供 的 方法 去 调用 数 
据 访 问 层 中 的 方法 ,达到 修改 数据 库 中 记录 及 页 面 显示 效果 的 目的 。 

BulletinList. aspx. cs 类 提供 了 显示 文章 列表 管理 页 面 的 后 台 代码 ,如 程序 5-8 所 示 。 
该 页 面 显示 某 个 栏目 下 的 所 有 文章 列表 ,并 提供 增加 、 删 除 和 修改 等 方法 的 链接 。 

程序 5-8 BulletinList. aspx. cs 
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ArticleAdd. aspx. cs 类 是 增加 某 个 栏目 下 文章 页 面 的 后 台 代 码 , 如 程序 5-9 所 示 。 
该 页 面 是 用 户 在 BulletinList. aspx 页 面 单 击发 表 新 文章 后 进入 的 页 面 。 把 用 户 在 页 面 各 
控件 中 添加 的 内 容 写 到 相关 数据 库 的 字段 中 。 

程序 5-9 ArticleAdd. aspx. cs 
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ArticleEdit. aspx. cs 类 是 修改 某 个 栏目 下 文章 页 面 的 后 台 代 码 . 如 程序 5-10 所 示 。 
该 页 面 是 用 户 在 Bulletin. aspx 页 面 单 击 修改 进入 的 页 面 。 把 用 户 在 页 面 各 控件 中 修改 
后 的 内 容 写 到 数据 库 的 相关 字段 中 。 

程序 5-10 ArticleEdit. aspx. cs 
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4. 用 户 表示 层 

在 培训 公告 模块 中 的 相关 用 户 表示 层 页 面 有 BulletinList. aspx、ArticleAdd. aspx 和 
ArticleEdit. aspx。 

(1) BulletinList. aspx 页 面 是 显示 培训 公告 栏目 下 的 所 有 文章 类 表 并 提供 增加 、 删 
除 和 修改 功能 的 链接 。 

BulletinList. aspx 页 面 的 前 台 Html 代码 如 程序 5-11 所 示 。 

程序 5-11 BulletinList. aspx 
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</table> 
< /asp:Content> 


(2) ArticleAdd. aspx 页 面 是 提供 用 户 增加 新 文章 的 页 面 ,具体 前 台 页 面 代 码 见 下 一 
节 培 训 公告 管理 模块 的 介绍 。 

(3) ArticleEdit. aspx 页 面 是 提供 用 户 修改 某 个 文章 的 页 面 ,具体 前 台 页 面 代码 见 下 
一 节 培 训 公 告 管理 模块 的 介绍 。 


5.4 功能 模块 介绍 


通过 前 三 节 的 介绍 ,已 经 对 模块 的 功能 、 数 据 库 及 三 层 结构 有 了 简单 了 解 ,下面 来 看 
一 下 各 个 模块 的 具体 实现 。 逻 辑 层 和 数据 层 在 前 面 三 层 结构 中 已 经 详细 介绍 过 ,本 节 会 
涉及 到 这 两 层 中 的 方法 ,在 这 里 只 作 简单 的 说 明 。 


5.4.1 首页 模块 
图 5-6 所 示 是 我 们 设计 出 的 首页 ,设计 中 实现 的 众多 功能 大 部 分 都 能 在 首页 中 得 到 体现 。 
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竺 员 mn 育 的 历 灿 可 以 旋 社 19 时 纪 神 汪 亿 天 村 南通 桥 是 埋 。 但 时 随 兰 先进 的 后 息 技术 ， 恩 是 Ian 的 
和 天 和 和 本 生生 化 的 下 于 直 站 的 人 入 提 几 了 
口 管理 员 指认 ， 拓 旦 ， 入 种 而 日 ， 技 术 女 挝 ， 学 加 和 次 必 和 大 量 全 有 “各 
Ct Nea 
用: 不 全 于 志和 和 和 加 办 只 胃 洒 书 帮 
Ne 大 和 全 
区: 16366 


和 [让 而 站 em? “ 远 手 笋 再 的 晤 所 管理 只。 20070106 
运 和 教育 抱 隐 六 苦 理 200701.05 


上 FEI | wen moa 


六 张 = 0070r06 
a 张 = m0 
现世: 
解 焉 思考 习 虽 


MR 
“新 并 


更 名 >> 
关于 闫 们 联系 共 们 机 有 全 作 。 甘 机 声 芋 。 招 队 传 息 。 况 关 地 图 3 和 到 向。 Ex 
质 和 所有。 保 时 所 有 权利 - 


图 5-6 首页 (Index. aspx、Index. aspx. cs) 
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从 图 5-6 中 可 以 看 出 ,首页 的 结构 非常 简单 ,明显 地 可 以 看 出 被 分 割 出 的 各 个 子 单 
元 ,从 上 到 下 分 别 是 网 站 标致 (Logo)、 导 航 栏 的 连接 (系统 首页 、 系 统 简介 、 培 训 公 告 、 学 
习 简报 ,答疑 解 惑 ,作业 展示 .思考 习题 和 友情 链接 )、 登 录入 口 ,学 习 简报 栏目 .答疑 解 惑 
栏目 友情 链 接 栏 目 、 系 统 简介 栏目 .培训 公告 栏目 .作业 展示 栏目 和 思考 习题 栏目 。 

从 图 5-6 中 还 可 以 看 到 ,首页 中 的 某 些 栏目 只 是 简单 的 文字 链接 ,如 友情 链接 等 。 其 
余 栏目 如 学 习 简报 栏目 ,答疑 解 惑 栏目 .系统 简介 栏目 .培训 公告 栏目 作业 展示 栏目 和 思 
考 习题 栏目 等 是 纯 文 字 文章 列表 。 下 面 将 分 别 介绍 以 上 栏目 的 实现 方法 。 

首先 介绍 系统 简介 栏目 .如 图 5-7 所 示 。 


系统 简介 


三 义 上 来 说 ， 远程 教育 是 指 格 课 件 传送 给 外 地 的 一 处 或 多 处 学 员 的 教育 。 依 照 这 个 定义 ， 远 程 教 
和 但 是 随 著 先进 的 信息 技术 ,特别 是 Intemet 的 

， 远程 教育 的 特征 发 生 了 评 刻 的 变化 。 的 确 ， 技术 的 迅速 发 展 不 新 向 远程 教 育 的 传统 定 久 提出 了 
后: 结果 ， 各 种 项 目 ， 技 术 支 持 ， 学 员 和 媒体 都 大 量 使 用 “运程 教育 ”这 一 本 语 

远程 教育 是 拉 二 De be 内 的 i 计算 机 技术 把 二 训 课 
程 传送 到 远 处 ( 校园 外 ) 的 教 运程 教育 的 定义 不 包括 专门 在 校园 内 及 只 通过 书面 形式 进行 的 
民生 (这 过 自 要 中 也 人 全 站 让 的 提 于， 其 中 一 些 指 导 其 看 全 如 


图 5-7 系统 简介 栏目 


要 实现 这 样 的 效果 ,其 前 台 代码 片段 如 程序 5-12 和 程序 5-13 所 示 。 
程序 5-12 首页 中 的 系统 简介 栏目 (Index. aspx) 


< table width= "530" border= "0" cellpadding= "0" cellspacing="0" class="bd"> 
<asp:Label ID="SystemIntro" runat= "server">< /asp:Label> 
</table> 


程序 5-13 首页 中 的 系统 简介 栏目 后 台 代 码 (Index. aspx. cs) 


Protected string modelnamextjj; 
Protected void Page Load (object sender, EventArgs e) 
{ 
modelnamextjj=this.Page.Server.UrlEncode ("> 系统 简介 "); 
StringBuilder sbl=new StringBuilder (); 
DataTable IntroTable=new DataTable () 7 
IntroTable= IndexObject .GetSystemIntro(); 
string systemintro= IntroTable.Rows[0] ["Intro"] .Tostring(); 
sb]1. Append (" gnbsp; snbsp; gnbsp; gnbsp; snbsp; snbsp; &nbsp; gnbsp; ") . Append (system- 
intro.ToString () .Substring (0, 296)) .Replace("\r\n", 
"<br> gnbsp; gnbsp; inbsp; gnbsp; gnbsp; gnbsp; tnbsp; gnbsp;") .Append ("<a target="_ 
blank' class= "link02" 
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通过 调用 IndexObject 的 方法 GetSystemIntro 来 获得 系统 简介 的 内 容 。GetSystem- 
Intro 方 法 所 涉及 的 SQL 语句 如 下 所 示 。 


下 面 青 实现 另 一 个 栏目 一 一 培训 公告 栏目 ,如 图 5-8 所 示 。 


图 5-8 培训 公告 栏目 


要 实现 这 样 的 效果 ,其 前 台 代 码 片段 如 程序 5-14 和 程序 5-15 所 示 。 
程序 5-14 ”首页 中 的 培训 公告 栏目 (Index. aspx) 


程序 5-15 ”首页 中 的 培训 公告 栏目 后 台 代 码 (Index. aspx. cs) 
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通过 调用 IndexObject 的 方法 GetPxgg 来 获得 培训 公告 的 ID 号 .标题 发布 者 和 发 
布 时 间 ,按照 发 布 时 间 的 先后 顺序 在 页 面 上 显示 最 新 发 布 的 5 篇 培训 公告 。 当 用 户 单 击 
培训 公告 的 标题 时 进入 培训 公告 的 文章 浏览 页 面 , 当 单 击 * 更 多 ”时 进入 培训 公告 的 栏目 
页 面 (显示 所 有 的 培训 公告 列表 ) 。GetPxgg 方法 所 涉及 的 SQL 语句 如 下 所 示 。 


接 下 来 实现 另 一 个 栏目 一 一 作业 展示 栏目 ,如 图 5-9 所 示 。 
要 实现 这 样 的 效果 ,其 前 台 代 码 片段 如 程序 5-16 和 程序 5-17 所 示 。 
程序 5-16 首页 中 的 作业 展示 栏目 (Index. aspx) 
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图 5-9 作业 展示 栏目 


程序 5-17 首页 中 的 作业 展示 栏目 后 台 代 码 (Index. aspx. cs) 
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通过 调用 IndexObject 的 方法 GetShowHomeWork 来 获得 学 生 回答 作业 的 ID 号 、 作 
业 的 标题 .学生 的 姓名 和 回答 作业 的 时 间 ,按照 分 数 的 高 低 排 序 在 页 面 上 显示 分 数 最 高 的 
5 篇 作业 答卷 。 当 用 户 单 击 作业 的 标题 时 进入 作业 的 浏览 页 面 , 当 单 击 * 更 多 ”时 进入 作 
业 展 示 的 栏目 页 面 (显示 所 有 的 作业 展示 列表 )。GetShowHomeWork 方法 所 涉及 的 
SQL 语句 如 下 所 示 。 


下 面 再 来 介绍 一 下 友情 链接 栏目 ,如 图 5-10 所 示 。 


5-10 ”友情 链接 栏目 


要 实现 这 样 的 效果 ,其 前 台 代 码 片段 如 程序 5-18 和 程序 5-19 所 示 。 
程序 5-18 首页 中 的 友情 链接 栏目 (Index. aspx) 
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程序 5-19 首页 中 的 友情 链接 栏目 后 台 代 码 (Index. aspx. cs) 


通过 调用 IndexObject 的 方法 GetFriendshipLink 来 获得 友情 链接 的 名 称 及 链接 地 
址 ,按照 建立 链接 的 时 间 排 序 , 得 到 最 新 建立 的 4 个 链接 。 当 用 户 单 击 友情 链接 的 名 称 
时 ,会 跳 转 到 相对 应 的 链接 页 面 , 当 单 击 * 更 多 ”时 进入 友情 链接 的 栏目 页 面 (显示 所 有 的 
友情 链接 列表 ) 。GetFriendshipLink 方法 所 涉及 的 SQL 语句 如 下 所 示 。 


首页 模块 的 完整 源 程序 在 Index. aspx 和 Index. aspx. cs 文件 中 。 这 里 只 是 对 系统 简 
介 栏 目 . 培 训 公告 栏目 .作业 展示 栏目 和 友情 链接 栏目 进行 了 介绍 。 对 于 学 习 简 报 栏目 、 
答疑 解 惑 栏目 的 代码 类 似 于 培训 公告 栏目 ,思考 习题 栏目 的 代码 类 似 于 作业 展示 栏目 。 
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5.4.2 栏目 页 模块 


有 了 首页 ,下 一 步 就 是 栏目 页 。 单 击 首页 各 个 栏目 的 “更 多 ”链接 ,可 以 进入 栏目 页 。 
栏目 页 可 以 看 作 是 各 个 栏目 的 首页 ,不 过 它 的 结构 比 首页 简单 ,只 要 包含 一 个 栏目 列表 就 
可 以 了 。 这 里 只 介绍 系统 简介 栏目 和 培训 公告 栏目 的 栏目 页 ,对 于 学 习 简报 栏目 .答疑 解 
惑 栏目 .作业 展示 栏目 .思考 习题 栏目 和 友情 链接 栏目 与 培训 公告 栏目 的 栏目 页 相似 ,在 
这 里 就 不 作 介绍 了 。 

下 面 首先 介绍 系统 简介 栏目 的 栏目 页 ,如 图 5-11 所 示 。 


当前 位 置 ; >> ”系统 主页 > 系统 简介 


广义 上 来 说 ,远程 教育 是 指 梅 课件 传送 结 外 地 的 一 处 或 多 处 学 员 的 教育 。 信 照 这 个 定义 ， 运 程 教育 的 历史 可 以 追溯 到 19 世 纪 30 
| 年 代 开 始 的 商业 函授 课程 。 但 是 随 着 先进 的 信息 技术 ， 转 别 是 Intemet 的 出 现 ， 远 程 教育 的 特征 发 生 了 深刻 的 变化 。 的 确 ， 技术 的 迅 
| 速 发 展 不 断 向 远程 教育 的 传 坟 定义 提出 了 挑战 。 结 果 ， 各 种 项 目 ， 技 术 支 持 ， 学 员 和 媒体 寿 大 量 使 用 “远程 教育 ”这 一 不 语 。 
| 远程 教育 是 指 通过 音频 、 视 频 ( 直播 或 录像 ) 及 包括 实时 和 在 实 时 在 内 的 计算 机 技术 把 培训 课程 传送 到 运 处 《 校园 外 ) 的 教 
| 育 。 这 一 远程 教育 的 定义 不 包括 者 门 在 校园 内 及 只 通过 书面 形式 进行 的 课程 ( 尽管 远程 教育 中 也 包括 一 些 在 杭 的 指导 或 考试 ， 其 中 
| 一 些 指导 也 有 可 能 是 通过 书面 来 进行 的 ) 。 
| 远程 教育 是 相对 于 常规 的 瘦 校 教育 的 一 种 教育 形式 ， 它 展 于 教育 机 构 实 施 的 教育 工作 或 教育 活动 的 苍 畸 ; 而 远程 笋 学 则 是 相对 
| 于 传统 课堂 教 学 的 一 种 教学 方式 ， 它 展 于 教师 与 当 生 之 间 教 学 行为 的 范畴 。 它 们 是 两 个 不 同 层面 的 概念 ， 吉 像 学 校 教育 与 课堂 教学 
| 的 区 别 一 样 ， 我 们 从 两 种 对 应 关系 上 根 容易 把 远程 教育 和 运程 教学 区 分 开采 。 远 程 教育 的 概念 要 大 于 远程 数学 的 概念 ， 远 程 教育 除 
| 了 通 羡 远 程 教学 外 , 还 有 数 育 信息 资源 开发 、 运 程 教 育 制度 建设 、 管 理 等 其 他 领域 ; 而 远程 笋 学 是 远程 教育 工作 的 核心 ， 对 两 者 应 


| 分 别 界定 或 表述 ,不 能 混为一谈 。 


图 5-11 系统 简介 栏目 的 栏目 页 


在 此 栏目 页 中 ,显示 了 系统 简介 的 完整 内 容 . 由 此 可 以 对 此 系统 有 简单 的 了 解 。 要 实 
现 这 样 的 效果 ,其 前 台 代码 片段 如 程序 5-20 和 程序 5-21 所 示 。 
程序 5-20 ”栏目 页 中 的 系统 简介 栏目 (SystemIntro. aspx) 


<table width= "710" border="0" cellpadding="10" cellspacing= "0" class="bdl"> 
<tr valign= "top"> 
<td class= "link01"” align= "left"> 
<asp:Label ID="AllSystemIntro" runat= "server">< /asp:Label> 
</td> 
Er 
</table> 


程序 5-21 栏目 页 中 的 系统 简介 栏目 后 台 代码 (SystemIntro. aspx. cs) 
StringBuilder sbl=new StringBuilder (); 


DataTable IntroTable=new DataTable(); 
IntroTable= IndexObject .GetSystemIntro(); 
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string systemintro= IntroTable-.Rows[0] ["Intro"] .ToString(); 

sb1 .Append (" snbspy snbsp; snbspy gnbsp; gnbsp; snbsp; gnbsp; gnbsp; ") . Append (sys- temintro. 
ToString () ) .Replace ("\r\n", "<br> gnbsp; gnbsp; gnbsp; gnbsp; gnbsp; gnbsp; énbsp; &nbsp; "); 
AllSystemIntro.Text=sbl.Tostring(); 


通过 调用 IndexObject 的 方法 GetSystemIntro 来 获得 系统 简介 的 详细 内 容 。sbl. 
Append("&nbsp; &nbsp; &-nbsp; &-nbsp; &-nbsp; &nbsp; &nbsp; &nbsp;") 是 用 来 在 页 
面 显 示 时 ,开头 空 两 格 。 当 把 数据 库 中 的 内 容 显 示 在 页 面 上 时 ,要 对 格式 进行 转换 , 因 
此 要 用 到 Replace("\r\n", "一 br 二 &nbsp; &-nbsp; &nbsp; &nbsp; &-nbsp; &nbsp; 
&.nbsp; &nbsp;") 对 格式 进行 转换 。GetSystemIntro 方法 所 涉及 的 SQL 语句 如 下 
所 示 。 


Select Article.Content as Intro 
from [Column] inner join Article on [Column] .ID=Rrticle.ColumnID 
Where [Column] .ColumnName= ' 系 统 简介 ' 


系统 简介 栏目 页 的 完整 源 程序 在 SystemIntro. aspx 和 SystemJIntro. aspx. cs 文 
件 中 。 
接 下 来 实现 另 一 个 栏目 


培训 公告 栏目 的 栏目 页 ,如 图 5-12 所 示 。 


系统 主页 。。 系统 简介 。 二 训 公 告 。。 学习 简报 短 蜂 解 四。 作业 展示 。。。 思考 习题 友情 链接 
骨 前 位 置 : >> 系统 主页 > 培训 公告 


培训 公告 


公告 标题 发 和 者 发 布 日 其 

品 运程 教育 的 特点 管理 员 1 2007.01.06 

口 远程 教育 的 柱 述 管理 员 1 2007-01-05 

口 远 程 教育 的 赵 扫 管理 员 1 2007.01.04 
信息 数 : 3 单 页 数 : 20 页 次 : 111 上 -页 下 -页 和 到 :第 [1 国 页 


关于 我 们 ”联系 我 们 ”项 目 合作 ”版 权 声明 ”招聘 信息 。 网 站 地 图 ”投入 指南 English 
版 权 所 有 。 保 留 所 有 权利 . 


图 5-12 培训 公告 栏目 的 栏目 页 


在 此 栏目 页 中 ,显示 了 培训 公告 列表 .包括 公告 标题 ,发 布 者 和 发 布 日 期 。 在 页 面 的 
下 方 设 有 分 页 功能 。 要 实现 这 样 的 效果 ,其 前 台 代码 片段 如 程序 5-22、 程 序 5-23 和 程 
序 5-24 所 示 。 

程序 5-22 栏目 页 中 的 培训 公告 栏目 (pxgg. aspx) 
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其 中 DataGrid 用 来 绑 定 数据 库 显示 培训 公告 列表 ,panel 中 的 控件 用 来 实现 分 页 
功能 。 
程序 5-23 ”栏目 页 中 的 培训 公告 栏目 列表 后 台数 据 绑 定 代 码 (pxgg. aspx. cs) 


此 段 代 码 用 于 实现 数据 绑 定 ,GetAllPxgg() 方 法 用 于 按照 发 布 时 间 的 顺序 显示 所 有 
培训 公告 标题 ,发布 者 和 发 布 日 期 , 它 所 涉及 的 SQL 语句 如 下 所 示 。 


程序 5-24 ”栏目 页 中 的 培训 公告 栏目 分 页 后 台 代码 (pxgg. aspx. cs) 
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以 上 是 对 分 页 部 分 代码 的 简单 编写 ,培训 公告 栏目 页 的 完整 源 程序 在 pxgg. aspx 和 
pxgg. aspx. cs 文件 中 。 


5.4.3 文章 浏览 模块 


浏览 者 最 终 的 目的 是 阅读 文章 的 内 容 , 在 这 里 只 介绍 培训 公告 和 作业 展示 的 文章 浏 
览 页 。 对 于 学 习 简 报 和 答疑 解 惑 的 浏览 页 与 培训 公告 相似 ,思考 习题 的 浏览 页 与 作业 展 
示 相 似 。 

首先 介绍 培训 公告 的 浏览 页 , 当 浏 览 者 浏览 培训 公告 的 文章 时 会 看 到 培训 公告 的 标 
题 发 布 者 、 发 布 的 时 间 和 正文 等 信息 。 所 设计 的 培训 公告 的 浏览 页 如 图 5-13 所 示 。 

从 图 5-13 中 可 以 看 到 ,培训 公告 的 文章 浏览 页 主要 由 三 个 部 分 组 成 。 要 实现 这 样 的 
效果 ,其 前 台 代码 片段 如 程序 5-25 和 程序 5-26 所 示 。 

程序 5-25 ”培训 公告 的 浏览 页 (pxgg-info. aspx) 
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远程 教育 的 概述 


发 者 : 管理 员 ! 。。 发 有 叶 间 ; 200701.05 


厂 义 上 来 说 ， 远 程 教育 是 指 将 课件 传送 给 外 地 的 一 处 或 多 处 学 员 的 教育 。 依 照 这 个 定义 ， 远 程 教育 的 历史 
可 以 刘 关 到 149 世纪 30 年 代 开始 的 商业 王 授 归程 。 介 是 陆 着 先进 的 信息 按 术 ， 特 别 是 Interna 的 出 现 ， 远 程 玖 育 的 
特征 发 生 了 深刻 的 变化 的确 ， 技 术 的 迅速 发 展 不 断 向 远程 教育 的 传统 定义 提出 了 挑战 。 结果 ， 各 种 项 目 ， 技 
林 支 尘 ， 学 员 和 媒体 部 大 量 使 用 “远程 教育 ”这 一 不 语 . 

远程 教育 是 指 通过 音频 、 视 频 (直播 或 录像 ) 及 包括 实时 和 FSKR 对 在 内 的 计算 机 技术 把 培训 讽 程 传送 到 远 
处 〈 械 园 外 ) 的 教育 。 这 一 远程 教育 的 定义 不 包括 专门 在 校园 凡 及 只 通辽 书面 形式 进行 的 谍 程 (尽管 远程 教育 
中 也 包括 一 些 右 校 的 指导 或 考试 ， 其 中 一 些 指导 也 有 可 能 是 通过 节 面 来 进行 的 ) ,， 

运程 教育 是 相对 于 常规 的 学 校 教育 的 一 种 教育 形式 ， 它 属于 教育 机 构 实 旅 的 教育 工作 或 教育 活动 的 菠 贱 ; 
而 远 香 歼 学 刚 是 f 对 于 传统 课堂 教学 的 一 种 才学 方式 ， 它 属于 玖 师 与 学 生 之 可 教学 行为 的 范畴 。 它 们 是 两 个 不 
同 层面 的 概念 ， 就 像 学 校 教育 与 课堂 教学 的 区 别 一 样 ， 我 们 从 两 种 对 应 关系 上 很 容易 把 远程 教育 和 远程 教学 区 
分 开 来 。 远程 菱 育 的 眉 念 加 大 于 远程 教学 的 机 念 ， 远 程 教育 际 了 烹 功 远程 教学 外 ， 还 有 教育 信息 六 源 开发 、 远 
程 娄 育 制 庆 建 设 、 管 理 竺 其 他 领域 ， 而 远程 教学 是 远程 教育 工作 的 核心。 对 两 者 应 分 别 界定 或 表 术 ， 不 能 混 汶 


图 5-13 培训 公告 的 文章 浏览 页 


<td colspan= "3" align= "center" bgcolor= "#ffffff" class= "txt"> 发 布 者 : 
<asp:Label ID= "authorname"” runat="server">< /asp:Label> 
&nbsp; gnbsp; &nbsp; &nbsp; gnbsp; snbsp; gnbsp; gnbsp; gnbsp; &nbsp; 
发 布 时 间 : <asp:Label ID="publishtime" runat="server">< /asp:Label></td 
></tr> 
<tr> 
<td colspan= "3" align= "left" bgcolor="# ffffff" class="txt"> 
<p align= "left"><asp:Label ID= "pxggcontent" runat="server">< /asp:Label>< /p> 
</td></tr> 
</table> 


程序 5-26 ”培训 公告 的 浏览 页 后 台 绑 定 (pxgg-info. aspx. cs) 


int ArticleID= Convert.ToInt32 (Request .Querystring["ArticleID"]); 
DataTable PxggContentTable=new DataTable (); 
PxggContentTable= IndexObject .GetPxggContent (ArticleID); 

string PxggTitle= PxggContentTable.Rows[0] ["ArticleTitle"] .Tostring(); 
pxggtitle.Text=PxggTitle;// 培 训 公 告 的 标题 
string AuthorName= PxggContentTable .Rows[0] ["UserName"] .Tbstring ();» 
authorname.Text=AuthorName;// 培 训 公 告 的 发 布 者 

string PublishTime= PxggContentTable .Rows [0] ["ArticlePublishTime"] .Tbstring (); 
publishtime.Text= PublishTime;// 培 训 公 告 的 发 布 时 间 
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StringBuilder sbl=new StringBuilder (); 
sb1. Append (" gnbsp; gnbsp; gnbsp; gnbsp; &nbsp; gnbsp; &nbsp; gnbsp;") . Append 
(PxggContentTable.Rows [0] ["ArticleContent"] .ToString ()) .Replace ("\r\n", "<br> gnbsp; 
&nbsp; gnbsp; snbsp; tnbsp; tnbsp; gnbsp; Enbsp; "); 
Pxggcontent .Text= sbl.ToString(); 


此 段 代码 实现 培训 公告 的 数据 绑 定 ,GetPxggContent() 方 法 用 于 通过 培训 公告 的 ID 
号 得 到 该 公告 的 相关 信息 ,主要 包括 公告 的 标题 ,公告 的 发 布 者 、 公 告发 布 的 时 间 及 公告 
的 内 容 , 其 中 Replace("\r\n", "二 br>>&nbsp; &nbsp; &nbsp; &-nbsp; &.nbsp; &nbsp; 
&nbsp; &-nbsp;") 用 来 转换 数据 库 中 正文 的 格式 ,GetPxggContent() 方 法 所 涉及 的 SQL 
语句 如 下 所 示 。 


select Article.Title as ArticleTitle, [User] .RealName as UserName, convert (Varchar (10), 
Article.PublishTime, 120) 
as ArticlePublishTime,Article.Content as ArticleContent 
from Article inner join [User] on Article.UserID= [User] .ID 
Where Article.ID=@ArticleID 


培训 公告 浏览 页 的 完整 源 程序 在 pxgg-info. aspx 和 pxgg-info. aspx. cs 文件 中 。 

接 下 来 介绍 作业 展示 的 浏览 页 , 当 浏 览 者 浏览 作业 展示 的 文章 时 会 看 到 作业 的 标题 
学 生 的 学 号 学生 的 姓名 、 作 业 的 要 求 . 学 生 回答 作业 的 内 容 、 教师 的 评语 及 作业 的 得 分 等 
内 容 。 所 设计 的 作业 展示 的 浏览 页 如 图 5-14 所 示 。 


远程 教育 
号 : 13 姓名 : 张 三 
远程 教育 概述 Ee 
内 容 : 


远 得 教育 是 措 通 过 侍 频 、 祝 频 〔 直 播 残 录 象 ) 及 包括 卖 时 和 非 赤 时 在 内 的 计算 机 技术 把 培 国 
训 课 程 传送 到 远 处 【校园 外 ) 的 教育 。 这 一 远程 教育 的 定义 不 包括 考 门 在 校园 内 及 只 通过 书面 
dd 尽管 远程 教育 中 也 包括 一 些 在 校 的 指导 或 考试 ， 其 中 一 些 指导 也 有 可 能 是 通 
E 行 | 


很 好 ,继续 加 力 ! 


国 


四 本 


图 5-14 作业 展示 的 文章 浏览 页 
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从 图 5-14 中 可 以 看 到 ,作业 展示 的 文章 浏览 页 主要 由 7 个 部 分 组 成 。 要 实现 这 样 的 
效果 ,其 前 台 代码 片段 如 程序 5-27 和 程序 5-28 所 示 。 
程序 5-27 作业 展示 的 浏览 页 (zyzs-info. aspx) 
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程序 5-28 ”作业 展示 的 浏览 页 后 台 绑 定 (zyzs-info. aspx. cs) 


此 段 代 码 实现 学 生 作业 的 数据 绑 定 .GetHomeworkbyAnswerID() 方 法 用 于 通过 学 
生 回答 作业 的 ID 号 得 到 该 学 生 的 作业 答卷 ,主要 包括 作业 的 题目 .学 生 学 号 .学 生 的 姓 
名 ,老师 布置 作业 的 要 求 ,学 生 回答 作业 的 内 容 、 教 师 的 评语 及 该 作业 所 得 的 分 数 , 它 所 涉 
及 的 SQL 语句 如 下 所 示 。 
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页 面 
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Select HomeWork.Title as HomeWorkTitle, [User] .ID as StudentID，[User] .RealName as Stu- 
dentName, HomeWork. Content as HomeWorkContent, Answer.Content as AnswerContent, Answer. 
TeacherComment as 
TeacherComment,Rnswer.HomeworkS as HomeworkS 
from [User] inner join Answer on [User] .ID=Answer.StudentID 
inner join HomeWork on HomeWork.ID= Answer.HomeworkID 
Where Answer .ID=@ AnswerID 


作业 展示 浏览 页 的 完整 源 程序 在 zyzs-info. aspx 和 zyzs-info. aspx. cs 文件 中 。 
5.4.4 用 户 登 录 模 块 
用 户 登 录 模 块 的 功能 是 控制 用 户 对 后 台 管 理 程序 的 访问 ,图 5-15 是 设计 的 登录 


用 户 登 录 模 块 通过 输入 的 用 户 名 和 密码 来 验证 用 户 身份 ,如 果 验 证 失败 ,拒绝 用 户 访 


问 ,将 会 提示 如 图 5-16 所 示 的 信息 。 


如 果 验 证 成 功 ,将 会 进入 登录 模块 的 另 一 个 页 面 ,接受 用 户 访问 ,如 图 5-17 所 示 。 


欢迎 登录 
远程 教育 管理 平台 9 


用 户 各 : FREE 


用 户 名 : admin 
SN: > 身 份 : 系 过 管理 局 
验证 码 : [4883 | 
奸 录 | | 注册 | 蕊 i 可 凤 ? 


进入 管理 锁 | | 退出 登录 | 


图 5-15 登录 页 面 图 5-16 登录 失败 的 提示 信息 图 5-17 ”验证 成 功 的 页 面 
当 用 户 单 击 “ 进 入 管理 端 "按钮 时 ,会 进入 远程 教育 的 管理 平台 ,如 图 5-18 所 示 ; 单 击 


“退出 登录 ”按钮 则 可 以 退出 登录 成 功 的 页 面 ,进入 远程 教育 系统 的 系统 主页 。 


当前 位 置 : >> 系统 管理 员 


。 用户 管 理 
。 个 人 信息 设置 
* 退出 


图 5-18 管理 平台 页 面 
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由 图 5-15 登录 页 面 可 以 看 到 , 它 主要 由 角色 选择 、 用 户 名 密码 、 验 证 码 、 登 录 图 片 、 
注册 图 片 和 忘记 密码 链接 7 个 部 分 组 成 。 要 实现 这 样 的 效果 ,其 前 台 代 码 片段 如 程 
序 5-29 所 示 。 

程序 5-29 登录 页 HTML 代码 (Login. aspx) 
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用 户 单 击 “登录 ”按钮 触发 Click 事件 ,如 程序 5-30 所 示 。 通 过 调用 checkloginObject 的 
方法 CheckStudentUserLogin、CheckTeacherLogin 和 CheckAdminLogin 分 别 验证 学 员 教师 
及 管理 员 的 用 户 名 和 密码 是 否 合法 ,如 果 合 法 则 跳 到 登录 后 的 页 面 ,如 图 5-17 所 示 。 

程序 5-30 ”Click 事件 验证 用 户 信息 (Login. aspx. cs) 
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CheckStudentUserLogin .CheckTeacherLogin 和 CheckAdminLogin 方法 所 涉及 的 
SQL 语句 如 下 所 示 。 


由 图 5-17 可 以 看 出 ,该 登录 以 后 的 页 面 主要 由 用 户 名 .身份 .进入 管理 端 和 退出 登录 
4 个 部 分 组 成 。 要 实现 这 样 的 效果 ,其 前 台 代码 片段 如 程序 5-31 所 示 。 
程序 5-31 ”登录 验证 后 页 面 的 HTML 代码 (Loged. aspx) 
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如 程序 5-32 所 示 , 当 用 户 成 功 登 录 以 后 .会 显示 用 户 的 用 户 名 和 身份 两 部 分 。 用 户 
成 功 登 录 以 后 ,用 户 的 信息 会 保存 在 Session["Current_User"] 中 。 
程序 5-32 ”成 功 登 录 状 态 (Loged. aspx. cs) 


如 程序 5-33 所 示 ,Loged. aspx. cs 提供 了 一 个 退出 登录 的 方法 , 当 用 户 单 击 “退出 登 
录 ” 按 钮 时 ,程序 将 清除 Session ,并 且 跳 转 到 开始 登录 的 页 面 。 
程序 $S-33 ”退出 登录 状态 (Loged. aspx. cs) 


如 程序 5-34 所 示 ,Loged. aspx. cs 还 提供 了 一 个 进入 管理 端的 方法 。 当 用 户 单 击 “ 进 
入 管理 端 " 按 钮 时 ,程序 将 进行 判断 , 若 此 时 Session[ "Current_User"] 二 二 null, 则 Ses- 
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sion 失效 ,提示 重新 登录 ; 若 Session 不 为 空 , 则 会 跳 转 到 管理 平台 的 页 面 。 
程序 5-34 ”进入 管理 端 状态 (Loged. aspx. cs) 


要 想 在 远程 教育 系统 登录 ,就 少不了 注册 个 人 信息 , 它 的 界面 如 图 5-19 所 示 。 


» [0140 


EA 


区 
图 5-19 注册 个 人 信息 


个 人 信息 注册 的 前 台 信 息 填写 程序 代码 如 程序 5-35 所 示 。 
程序 5-35 ”注册 个 人 信息 页 面 的 HTML 代码 (Register. aspx) 
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这 里 需要 注意 的 是 ,关于 验证 控件 的 使 用 ,在 前 面 的 章节 中 已 经 有 所 介绍 ,通过 Er- 
rorMessage 属性 指定 出 错时 显示 的 提示 。 再 来 看 看 它 的 后 台 是 如 何 处 理 这 些 数据 和 信 
息 的 。 因 为 后 台 的 处 理 程序 代码 很 长 ,所 以 把 它 分 开 来 讲述 ,更 为 全 面 的 代码 可 以 参考 程 
序 页 \WEB\Login\Register. aspx. cs。 

首先 看 一 下 图 5-19 上 的 验证 按钮 ,这 里 规定 ,如 果 数 据 库 中 已 经 存在 输入 的 用 户 名 ， 
则 单 击 验 证 按钮 时 会 提示 “此 用 户 名 已 被 占用 ”。 它 是 如 何 实 现 的 呢 ? 程 序 代码 如 程 
序 5-36 所 示 。 

程序 5-36 ”验证 用 户 名 (Register. aspx. cs) 
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在 程序 5-36 中 通过 调用 checklogin 的 方法 CheckUserNamelsAvailable 来 验证 所 输 
人 的 用 户 名 是 否 已 经 被 占用 。 如 果 用 户 名 没有 被 占用 , 则 所 输入 的 用 户 名 可 用 ;反之 ,所 
输入 的 用 户 名 不 可 用 。CheckUserNamelsAvailable 方法 所 涉及 的 SQL 语句 如 下 所 示 。 


新 增 用 户 的 操作 是 一 个 典型 的 数据 库 Insert 操作 ,如 程序 5-37 所 示 。 
程序 5-37 新 增 用 户 的 操作 (Register. aspx. cs) 
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在 程序 5-37 中 通过 调用 checklogin 的 方法 InsertUser 向 数据 库 中 插入 一 条 记录 , 添 
加 用 户 信 息 。InsertUser 方法 所 涉及 的 SQL 语句 如 下 所 示 。 


通过 上 面 的 介绍 ,已 经 对 登录 和 注册 有 了 简单 了 解 。 那 么 , 当 用 户 注册 以 后 ,在 系统 
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主页 登录 时 忘记 了 密码 怎么 办 呢 ? 这 就 会 涉及 到 怎样 找 回 密码 的 问题 。 下 面 是 设计 的 找 
回 密码 的 页 面 ,如 图 5-20 所 示 。 


图 5-20 找 回 密码 


从 图 5-20 中 可 以 看 到 ,该 页 面 由 输入 真实 姓名 、 身 份 证 号 码 、 确 定 和 取消 4 个 部 分 组 
成 。 找 回 密码 的 前 台 程 序 代码 如 程序 5-38 所 示 。 
程序 5-38” 找 回 密码 页 面 的 HTML 代码 (GetPassWord. aspx) 
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它 是 怎样 通过 输入 的 真实 姓名 和 身份 证 号 码 找 回 密码 的 呢 ? 程序 代码 如 程序 5-39 
所 示 。 
程序 5-39 ” 找 回 密码 (GetPassWord. aspx. cs) 
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在 程序 5-39 中 通过 调用 checklogin 的 方法 GetUserName 来 验证 该 用 户 是 否 已 经 注 
册 , 若 已 经 注册 , 则 可 以 找 回 密码 ;反之 ,不 能 找 回 密 码 。 通 过 调用 IndexObject 的 方法 
GetPassWordbyRealNameAndIDCardNumber, 由 输入 的 真实 姓名 和 身份 证 号 码 找 回 密 
码 。GetUserName 方法 所 涉及 的 SQL 语句 前 面 已 经 介绍 过 。 

PassWordbyRealNameAndIDCardNumber 方法 所 涉及 的 SQL 语句 如 下 所 示 。 


登录 模块 的 完整 源 程序 在 \WEB\Login 文件 夹 中 。 
5.4.5 导航 菜单 模块 


图 5-21 所 示 为 系统 管理 员 登 录 后 看 到 的 后 台 管 理 页 面 IndexMain. aspx。 该 页 面 由 
三 部 分 组 成 ,分 别 为 头 部 (页 面 上 方 ) 主体 (页 面 中 间 ) 和 尾部 (页 面 下 方 )。 主 体 部 分 又 分 
为 两 部 分 : 左边 部 分 和 右边 部 分 。 导 航 菜单 模块 就 是 左边 部 分 。 

学 员 和 教师 登录 后 ,进入 的 也 是 这 个 页 面 . 区 别 在 于 导航 菜单 中 的 内 容 不 同 , 因 为 导 
航 菜单 是 根据 角色 动态 加 载 的。 下 面 来 具体 介绍 导航 菜单 实现 的 原理 。 
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@ 司 -日 - 国 国 的 | 局 时 页 wmx @| 全 -如 四 -所 
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， 来 和 介 
， 后 公告 课程 名 : | 本 导 省 要 程 
， 他 习 骨 报 > : 
,PE 课程 名 任课 教师 
， 误 各 管理 = 

2 # | RD 
i [EE 
， 用 户 管理 
， 个 人 信息 设 和 
， 退出 


基于 我 们 | 其 系 我 人 | 版 权 声 明 | 拒 聘 信息 “| 网 站 地 图 | 投入 指南 
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5-21 后 台 管 理 页 面 (IndexMain. aspx) 


如 果 把 菜单 中 的 每 一 项 称 为 一 个 模块 ,那么 每 个 角色 所 对 应 的 模块 是 不 一 样 的 。 角 
色 与 模块 的 关系 是 通过 一 个 XML 来 配置 的 。 下 面 先 介绍 该 XML ,如 程序 5-40 所 示 。 
程序 5-40 InitList. xml 的 部 分 内 容 


<?xml Version="1.0"”encoding= "utf- 8" ?> 
<AccessPage> 
<InitPage> 
<Role>1< /Role> 
<ModuleName> 系统 简介 < /ModuleName> 
<ModuleEntrance> BulletinManage/BulletinList.aspx?ColumnID=1< /ModuleEntrance> 
</InitPage> 
<InitPage> 
<Role>1< /Role> 
<ModuleName> 课 程 管 理 < /ModuleName> 
< ModuleEntrance> CourseManage/Default .aspx< /ModuleEntrance> 
< /InitPage> 
< InitPage> 
<Role> 1< /Role> 
<ModuleName> 友 情 链 接 < /ModuleName> 
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由 于 篇 幅 有 限 , 上 面 是 XML 文件 的 部 分 内 容 。 该 XML 文件 名 为 InitList. xml, 根 节 
点 为 AccessPage. 根 节点 包含 很 多 子 节 点 InitPage, 其 中 每 个 InitPage 子 节点 对 应 一 个 菜 
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单 中 的 模块 。 下 面 详细 介绍 InitPage 子 节点 ,其 形式 如 下 。 


每 个 子 节点 InitPage 下 面 都 包含 三 个 子 节 点 Role、ModuleName 和 ModuleEn- 
trance。Role 是 对 应 数据 库 中 的 角色 编号 ; ModuleName 代表 模块 的 名 称 ; ModuleEn- 
trance 为 模块 的 链接 地 址 , 即 模块 所 对 应 页 面 的 相对 地 址 。 

在 该 系统 中 ,管理 员 有 9 个 模块 ,分 别 为 系统 简介 .培训 公告 .学 习 简 报 .答疑 解 惑 、 课 
程 管理 友情 链接 、 用 户 管理 ,个 人 信息 设置 和 退出 。 所 以 在 InitList. xml 中 应 有 9 个 
InitPage 节点 。 在 这 9 个 模块 中 ,Role 中 的 文本 都 应 为 管理 员 的 角色 编号 1, Modu- 
leName 中 的 文本 对 应 这 9 个 模块 的 名 称 ,ModuleEntrance 为 9 个 模块 的 链接 地 址 。 例 
如 ,系统 简介 的 ModuleEntrance 为 BulletinManage/BulletinList. aspx? ColumnID=1， 
因为 系统 简介 在 BulletinManage 文件 夹 的 BulletinList. aspx 中 。 由 于 系统 简介 、 培 训 公 
告 等 都 共用 该 页 面 ,所 以 加 上 查询 字符 串 ?”ColumnID 二 1 以 区 分 不 同 模块 。 

学 员 和 教师 类 似 。 如 图 5-22 和 图 5-23 所 示 。 


图 5-22 学 员 登 录 后 的 导航 菜单 图 5-23 教师 登录 后 的 导航 菜单 


程序 5-41 所 示 为 导航 菜单 的 前 台 HTML 代码 。 
程序 5-41 ”导航 菜单 的 HTML 代码 (IndexMain. aspx) 
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需要 注意 的 是 ,服务 器 控件 HyperLink 的 Text 和 NavigateUrl 都 是 后 台 绑 定 , 稍 后 
会 讲 到 。Target 属性 的 值 为 frmLevelTree, 要 理解 这 里 需要 清楚 主体 部 分 右边 的 作用 。 
右边 是 一 个 iframe, 用 来 承载 左边 导航 的 页 面 。 其 前 台 HTML 代码 如 程序 5-42 所 示 。 

程序 5-42 ”主体 右边 部 分 的 HTML 代码 (IndexMain. aspx) 


Iframe 的 ID 为 frmLevelTree, 正 好 是 前 面 讲 到 的 服务 器 控件 HyperLink 的 Target 
的 值 ,表明 导航 菜单 链接 的 页 面 都 是 在 Iframe 显示 .也 就 是 页 面 主体 部 分 的 右边 。 

接 下 来 介绍 实现 导航 菜单 的 后 台 核 心 代码 ,如 程序 5-43 所 示 。 

程序 5-43 ”导航 菜单 实现 的 后 台 代码 (IndexMain. aspx. cs) 


首先 把 指定 位 置 的 XML 文件 中 模块 信息 读 取 到 数据 集中 ,再 根据 视图 的 过 滤 属 性 ， 
过 滤 掉 不 是 目前 登录 角色 所 应 有 的 模块 信息 ,并 以 此 视图 为 数据 列表 DIMenusTop 的 数 
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据 源 进行 绑 定 ,从 而 达到 可 以 根据 不 同 登 录用 户 的 角色 显示 不 同 的 菜单 信息 。 
到 这 里 ,导航 菜单 已 经 介绍 完毕 ,所 有 代码 都 在 系统 根 目录 下 IndexMain. aspx、In- 
dexMain. aspx. cs 中 。 


5.4.6 文章 管理 功能 模块 


1. 功能 描述 

文章 管理 功能 模块 分 为 系统 简介 .培训 公告 .学习 简报 和 答疑 解 惑 4 个 版 块 。 对 所 有 
版 块 文章 进行 管理 ,有 查询 .发布 ` 修 改 和 删除 4 种 操作 ,不 同 的 用 户 角色 享有 不 同 的 权 
限 。 只 有 管理 员 能 对 文章 进行 查询 发布. 修改 和 删除 等 操作 ,其 他 学 员 都 只 能 进行 浏览 。 
系统 简介 .培训 公告 .答疑 解 惑 和 学 习 简 报 等 管理 模块 在 具体 实现 上 基本 相同 ,在 此 仅 以 
说 训 公告 管理 版 块 为 例 , 就 不 再 一 一 具体 介绍 。 

2. 页 面 实 现 

显示 文章 列表 的 管理 页 面 的 实现 代码 参见 5. 3 节 中 分 层 结构 部 分 的 详细 介绍 ,相关 
文件 为 BulletinList. aspx 和 BulletinList. aspx. cs。 

显示 文章 列表 的 管理 页 面 如 图 5-24 所 示 。 


有 位置: >> 厌 统 主 而 
《 志 区 城内 旺 杀 在 丰 栏 月 下 本 109 文章 天 各 》 


标题 发 布 者 发 布 时 间 修 驶 到 除 

.3 管理 1 2007.1600000 (Ss gm 

i 入 于 及! 2007.1-400000 区 小 划 i 

大 得 禾 育 EDfR 管理 及 1 2007.1.500000 [ 千 可 [73 
发 现形 文 于 


图 5-24 显示 文章 列表 的 管理 页 面 


增加 文章 页 面 (ArticleAdd. aspx) 的 Html 实现 代码 如 程序 5-44 所 示 。 
程序 5-44 ArticleAdd. aspx 


<table width= "772" height= "20" border="0" align= "center" cellpadding= "0" cellspacing= 


he 
<tr> 
<td style= "width: 55px; height: 3px"> 标 题 : < /td> 
<td style= "width: 550px; height: 3px" align= "left"> 
<asp:TextBox ID= "TextBoxTitle" runat= "server" Width="550px">< /asp: 
TextBox> 


<asp: RequiredFieldValidator ID="RequiredFieldValidatorl" runat=" 
server" ControlToValidate= "TextBoxTitle"” ”ErrorMessage- "文章 标题 不 能 为 空 " Font- size 
= "Small" 
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(ArticleAdd. cs 文件 参见 上 一 节 三 层 结构 中 的 相关 文件 ) 
增加 培训 公告 文章 的 页 面 效 果 如 图 5-25 所 示 。 


图 5-25 ”发 表 新 文章 页 面 


修改 文章 的 功能 是 指 当 有 管理 权限 的 用 户 单 击 相应 文章 的 修改 按钮 时 跳 转 到 的 页 
面 ,页 面 的 控件 中 显示 文章 的 原 有 内 容 。 当 用 户 编辑 完 后 单 击 “确定 ”按钮 将 修改 数据 库 
中 的 文章 信息 。 

修改 文章 的 页 面 (ArticleEdit. aspx) Html 代码 如 程序 5-45 所 示 。 

程序 5-45 ArticleEdit. aspx 
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(ArticleEdit. cs 文件 参见 上 一 节 三 层 结构 中 的 相关 文件 ) 
修改 文章 的 页 面 效果 如 图 5-26 所 示 。 


s.4.7 用 户 管理 模块 


用 户 管理 模块 是 管理 员 才 具有 权限 操作 的 模块 。 具 有 的 操作 权限 为 查询 、 删 除 和 增 
加 。 该 模块 主要 由 UserManage 文件 夹 下 的 Default. aspx 和 AddUser. aspx 两 个 页 面 实 
现 。Default. aspx 如 图 5-27 右边 所 示 。 

其 中 用 户 列表 由 GridView 控件 实现 ,其 前 台 的 HTML 页 面 的 代码 如 程序 5-46 
所 示 。 
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图 5-27 用 户 管理 模块 首页 (Default. aspx) 


程序 5-46 ”GridView 控件 的 前 台 HTML 代码 (Default. aspx) 


第 5 章 ”远程 教育 系统 实例 


由 代码 可 知 ,用 户 列 表 是 由 服务 器 控件 GridView 在 后 台 动 态 绑 定 的 ,具体 实现 如 程 
序 5-47 所 示 。 
程序 5-47 ”用 户 列表 绑 定 的 后 台 代 码 (Default. aspx. cs) 


当 首 次 加 载 页 面 时 ,调用 GV_DataBind 方法 ,该 方法 的 参数 是 另 一 个 方法 GetUser- 
List 的 返回 值 。GetUserList 方法 主要 由 UserManageObject 类 的 GetUsers 方法 实现 。 

UserManageObject 是 逻辑 层 的 用 户 管理 类 ,包装 了 与 用 户 管理 相关 的 方法 。Ge- 
tUsers 方法 是 获取 用 户 列表 ,参数 为 用 户 名 。 当 用 户 名 为 空 时 ,获取 全 部 用 户 列表 ; 当 用 
户 名 不 为 空 ,模糊 查询 ,获取 满足 条 件 的 用 户 列表 。 返 回 值 为 一 个 DataTable 型 的 列表 。 

GetUserList 方法 中 定义 一 个 DataTable 型 的 变量 dt 接收 GetUsers 方法 的 返回 值 ， 
并 将 dt 返回 。 

GV_DataBind 方法 以 dt 为 参数 ,并 将 dt 作为 服务 器 控件 GV_UserList 的 数据 源 ， 
进行 绑 定 ,从 而 显示 全 部 用 户 列表 。 
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其 中 ,GetUsers 方法 设计 的 SQL 语句 如 下 所 示 。 
当 参 数 为 空 时 ,SQL 语句 如 下 。 


当 参 数 不 为 空 时 ,SQL 语句 如 下 。 


用 户 的 删除 是 由 GridView 控件 的 RowCommand 事件 完成 ,CommandName 一 
"DeleteUser" 指 定 了 命令 名 称 。CommandArgument 二 二 %#Eval("ID") % 放 ' 表 明 命 令 
的 参数 是 后 台 绑 定 的 用 户 编号 。 其 具体 实现 如 程序 5-48 所 示 。 

程序 5-48 ”删除 用 户 的 实现 (Default. aspx. cs) 
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当 单 击 “ 删 除 ” 按 钮 时 ,触发 GridView 控件 的 RowCommand 事件 GV_ UserList_ 
RowCommand。 根 据 用 户 命令 DeleteUser, 会 调用 Delete 方法 。Delete 方法 主要 有 Use- 
rManageObject 类 的 DeleteUser 方法 。DeleteUser 方 法 为 删除 指定 用 户 , 参 数 为 用 户 编 
号 。Delete 方法 执行 完 后 ,会 重新 绑 定 ,显示 删除 后 的 用 户 列表 。DeleteUser 方法 涉及 的 
SQL 语句 如 下 。 


用 户 的 查询 和 新 增 的 前 台 HTML 代码 如 程序 5-49 所 示 。 
程序 5-49 ”查询 和 新 增 的 HTML 代码 (Default. aspx) 


单 击 “ 查 询 ” 按 钮 和 “新 增 " 按 钮 ,触发 的 事件 分 别 为 select_Click、Add_Click。 后 台 代 
码 如 程序 5-50 所 示 。 
程序 5-50 ”新 增 和 查询 时 间 后 台 代 码 (Default. aspx. cs) 


查询 用 户 跟前 面 初始 化 用 户 列表 的 代码 类 似 , 不 同 的 是 : 查询 用 户 时 ,是 根据 用 户 名 
模糊 查询 ,参数 不 为 空 ,用 到 的 SQL 语句 是 前 面 介绍 的 参数 不 为 空 的 SQL 语句 ,所 以 得 
到 的 是 满足 条 件 的 用 户 , 而 并 非 全 部 用 户 。 将 得 到 的 部 分 用 户 列表 作为 数据 源 , 重 新 绑 
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定 ,显示 出 来 。 
增加 事件 主要 是 一 个 跳 转 方法 , 跳 转 到 AddUser. aspx, 如 图 5-28 所 示 , 并 由 AddUs- 
er. aspx 实现 增加 用 户 功能 。 


要 前 友 寺 3 >> 系 殉 秋 再 页 > 用 户 宫 天 


9 增加 用 户 页 
A: OR Om 


图 5-28 新 增 用 户 页 面 (AddUser. aspx) 


由 系统 的 需求 可 知 , 管 理 员 只 可 以 添加 新 的 管理 员 和 教师 ,添加 时 必须 选择 两 者 角色 
之 一 。 管 理 员 只 需要 添加 用 户 名 和 密码 ,添加 完 后 ,由 管理 员 分 配 用 户 名 和 密码 ,其 他 的 
用 户 信息 由 使 用 该 用 户 名 的 用 户 在 个 人 信息 配置 模块 中 添加 。AddUser. aspx 页 面 的 前 
台 HTML 代码 如 程序 5-51 所 示 。 

程序 5-51 增加 用 户 的 前 台 HTML(AddUser. aspx) 
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其 中 ,用 到 了 验证 控件 RequiredFieldValidator 和 CompareValidator, 用 于 防止 用 户 
名 为 空 和 两 次 输入 的 密码 不 一 样 。 当 添加 完毕 , 单 击 “ 提 交 ” 按 钮 ,触发 提交 事件 bt_Sub- 
mit_Click。 也 可 以 单 击 * 返 回 ? 按 钮 ,触发 bt_Cancel_Click 返回 到 用 户 管理 首页 
(Default. aspx) ,后 台 代码 如 程序 5-52 所 示 。 

程序 5-52 ”提交 事件 和 返回 事件 的 后 台 代码 (AddUser. aspx. cs) 
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在 提交 事件 时 间 中 ,首先 由 Page. IsValid 判断 页 面 是 否 通过 验证 ,只 有 通过 验证 , 即 
Page. IsValid 返回 True, 才 能 继续 执行 提交 事件 。UserManageObject 的 AddUser 方法 
为 增加 用 户 ,参数 为 用 户 名 、 密 码 和 角色 编号 。 涉 及 到 的 SQL 语句 如 下 。 


返回 事件 比较 简单 ,就 是 重 定向 到 用 户 管理 首页 。 
用 户 管理 模块 的 所 有 页 面 都 在 系统 根 目录 下 的 UserManage 文件 夹 中 。 


5.4.8 课程 管理 模块 


课程 管理 模块 是 管理 员 才 具有 权限 操作 的 模块 。 具 有 的 操作 权限 为 查询 、 删 除 、 修 改 
和 增加 。 该 模块 主要 由 CourseManage 文件 夹 下 的 课程 管理 首页 (Default. aspx) ,增加 课 
程 页 面 (AddCourse. aspx) 和 修改 课程 页 面 (UpdateCourse. aspx) 这 三 个 页 面 实现 。 
Default. aspx 如 图 5-29 右边 所 示 。 

其 中 课程 列表 由 GridView 控件 实现 ,其 前 台 的 HTML 页 面 的 代码 如 程序 5-53 
所 示 。 

程序 5-53 GridView 控件 的 前 台 HTML 代码 (Default. aspx) 
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图 5-29 课程 管理 首页 (Default. aspx) 


由 上 面 程序 可 知 ,GridView 控件 是 后 台 动态 绑 定 的 ,实现 代码 程序 5-54 所 示 。 
程序 5-54 ”课程 列表 绑 定 的 后 台 代 码 (Default. aspx. cs) 
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注 : 到 这 里 会 发 现 , 不 论 是 页 面 样式 .前 台 HTML 代码 .后 台 实 现代 码 , 课 程 管理 和 
用 户 管理 ,还 有 后 面 将 要 讲 到 的 链接 管理 都 很 类 似 , 用 的 是 一 个 CSS 样式 ,统一 的 编程 思 
路 ,程序 代码 和 用 户 管理 非常 类 似 。 所 以 在 讲 到 课程 管理 和 链接 管理 时 ,不 再 一 一 详 述 ， 
将 只 是 简单 介绍 。 

CourseManageObject 是 逻辑 层 的 课程 管理 类 ,包装 了 与 课程 管理 相关 的 方法 。Get- 
Courses 方法 是 获取 课程 列表 ,参数 为 课程 名 。 当 课程 名 为 空 时 ,获取 全 部 课程 ; 当 课程 
名 不 为 空 ,模糊 查询 ,获取 满足 条 件 的 课程 。 

当 页 面 加 载 时 .获取 全 部 课程 ,所 以 参数 为 空 。GetCourses 方法 设计 的 SQL 语句 如 
下 所 示 。 

当 参 数 为 空 时 ,SQL 语句 如 下 。 


当 参 数 不 为 空 时 ,SQL 语句 如 下 。 


课程 的 删除 和 修改 是 由 GridView 控件 的 RowCommand 事件 完成 , CommandName 
三 "UpdateCourse" 和 CommandName 王 "DeleteCourse" 指 定 了 命令 名 称 . 分 别 表示 修改 
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课程 和 删除 课程 。CommandArgument 二 ' 二 %#Eval("ID") % 放 ' 表 明 命 令 的 参数 是 后 
台 绑 定 的 课程 编号 。 其 具体 实现 如 程序 5-55 所 示 。 
程序 5-55 ”删除 和 修改 事件 的 后 台 代 码 (Default. aspx. cs) 


当 单 击 删 除 或 修改 按钮 时 ,触发 GridView 控件 的 RowCommand 事件 GV_CourseL- 
ist_RowCommand。 根 据 CommandName 命令 ,执行 Delete 或 Update 方法 。 

Delete 方 法 主要 由 CourseManageObject 类 的 DeleteCourse 方法 完成 。Delete- 
Course 方法 为 删除 指定 课程 ,参数 为 课程 编号 。Delete 方法 执行 完 后 ,会 重新 绑 定 , 显 示 
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删除 后 的 课程 列表 。DeleteCourse 方法 涉及 的 SQL 语句 如 下 。 


Update 方 法 比较 简单 ,将 当前 页 面 跳 转 到 修改 课程 页 面 UpdateCourse. aspx, 如 
5-30 所 示 ,并 传递 一 个 参数 ID, 值 为 当前 修改 的 课程 编号 。 


位 要 :> 天生 若 棕 页 > 课程 和 理 


9 修改 课程 页 


课程 名 ; 
任课 教师 : Teacher! 国 
加 四 


图 5-30 ”修改 课程 页 面 (UpdateCourse. aspx) 


修改 课程 页 面 的 前 台 HTML 代码 如 程序 5-56 所 示 。 
程序 5-56 ”修改 课程 页 面 的 前 台 HTML 代码 (UpdateCourse. aspx) 


如 程序 5-56 所 示 , 有 一 个 验证 控件 RequiredFieldValidator, 用 于 限制 用 户 名 不 能 为 
空 。 修 改 课程 页 面 的 后 台 代码 实现 如 程序 5-57 所 示 。 
程序 5-57 ”修改 课程 页 面 的 后 人 台 代 码 (UpdateCourse. aspx. cs) 
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如 程序 5-57 所 示 , 页 面 第 一 次 加 载 时 ,首先 执行 ddlDatabind 方法 ,该 方法 通过 Use- 
rManageObject 类 的 GetTeachers 从 数据 库 中 获取 教师 列表 .并 以 获取 的 列表 作为 下 拉 
列表 ddl_Teacher 的 数据 源 ,进行 绑 定 。GetTeachers 方法 涉及 的 SQL 语句 如 下 所 示 。 
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然后 获取 查询 字符 串 课程 编号 (ID) 的 值 , 并 以 该 课程 编号 为 参数 ,执行 CourseMana- 
geObject 类 的 GetCoursesbyID 方法 ,获取 该 指定 的 课程 信息 ,初始 化 课程 名 称 和 任课 教 
师 。GetCoursesbyID 方法 设计 的 SQL 语句 如 下 所 示 。 


当 单 击 “提交 ”按钮 ,触发 bt_Submit_Click 事件 ,该 事件 主要 是 完成 修改 功能 ,由 
CourseManageObject 的 UpdateCourse 方法 实现 , 该 方法 的 参数 为 CourseID、 
CourseName 和 TeacherID。 设 计 到 的 SQL 语句 如 下 所 示 。 


当 单 击 * 返 回 ? 按 钮 ,触发 bt_Cancel_Click 事件 ,返回 到 课程 管理 首页 。 

在 图 5-29 所 示 的 课程 管理 页 面 中 ,还 有 查询 和 新 增 课 程 功能 ,其 前 台 HTML 的 页 面 
如 程序 5-58 所 示 。 

程序 5-58 ”查询 和 新 增 课程 的 前 台 HTML 代码 (Default. aspx) 


单 击 查询 和 新 增 课程 ,触发 select_Click 和 Add_Click 事件 ,后 台 代码 如 程序 5-59 
所 示 。 
程序 5-59 ”查询 和 新 增 课程 的 后 台 代 码 (Default. aspx. cs) 
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查询 事件 跟 课程 列表 初始 化 类 似 , 只 不 过 这 里 课程 名 不 为 空 ,GetCourseList 方法 调 
用 有 参数 的 GetCourses 方法 ,得 到 满足 条 件 的 课程 列表 ,再 进行 GridView 的 绑 定 。 
新 增 课程 事件 很 简单 ,将 当前 页 面 跳 转 到 增加 课程 页 面 (AddCourse. aspx), 如 
5-31 所 示 , 由 增加 课程 页 面 完 成 新 增 课程 功能 。 
| 当前 位 置 : >> 率 统 管理 员 > 课程 管理 


图 5-31 增加 课程 页 面 (AddCourse. aspx) 
增加 课程 页 面 的 前 台 HTML 代码 跟 修改 类 似 , 只 是 提交 事件 不 同 ,如 程序 5-60 
所 示 。 
程序 5-60 ”提交 事件 的 后 台 代 码 (AddCourse. aspx. es) 


提交 事件 主要 由 CourseManageObject 类 的 AddCourse 方法 完成 增加 课程 功能 ,该 
方法 的 参数 是 课程 名 称 (CourseName) ,任课 教师 编号 (TeacherID)。 涉 及 的 SQL 语句 如 
下 所 示 。 
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VALUES ( 
@ CourseName, 


@ TeacherID 
) 
返回 事件 比较 简单 ,就 是 跳 转 到 课程 管理 首页 。 
课程 管理 模块 的 所 有 页 面 都 在 系统 根 目 录 下 的 CourseManage 文件 夹 中 。 


5.4.9 作业 展示 模块 (教师 ) 

作业 展示 模块 是 针对 教师 和 学 员 而 言 的 , 当 用 户 以 教师 或 者 学 员 的 身份 登录 时 就 会 
在 管理 平台 看 见 作 业 展 示 模 块 。 教 师 和 学 员 所 对 应 的 作业 展示 模块 不 同 , 以 教师 身份 登 
录 时 ,作业 展示 模块 具有 教师 发 布 新 的 作业 、 修 改作 业 、 删 除 作业 及 批改 学 员 作 业 的 功能 。 


首先 ,看 一 下 以 教师 身份 登录 时 作业 展示 的 页 面 ,如 图 5-32 所 示 。 


当前 位 置 : >> 教师 > 作业 展示 


请 先 选择 课程 ， 再 点 击 技 钮 ! 


x EE EEE) 
课程 名 称 教师 姓名 作业 标题 发 布 日 期 修改 
语文 教师 1 远程 教育 的 特点 2008-1-21625:10 修改 制 除 
语文 hl 远程 邹 育 的 概述 2008-1-3152300 修改 扣除 
语文 教师 1 远程 教育 的 趋势 2008-1-417:4500 修改 支队 


图 5-32 ”作业 展示 页 面 (教师 ? 


从 图 5-32 可 以 看 出 , 当 教 师 选 择 课程 后 , 单 击 * 查 询 作业 ”按钮 时 会 看 到 该 教师 | 
针对 该 课程 所 发 布 的 作业 ,包括 课程 名 称 、 教 师 姓 名 、 作 业 标 题 \ 发 布 日 期 修改 和 删 
部 分 。 要 实现 这 样 的 效果 ,其 前 台 代码 片段 如 程序 5-61 所 示 。 

程序 5-61 ”作业 展示 页 面 的 HTML 代码 (TeacherHomework. aspx) 


<table runat= "server" style="width: 100% ; height: 86px" id= "table"> 
<tr> 
<td colspan= "2" style= "height: 26px; width: 100% ;"> 
<asp:DropDownList ID="Course" runat="server" RutoPostBack= "true"/ > 
< asp: Button ID="Buttonl”" runat=" server" OnClick="Buttonl Click" Text= 


"查询 作业 " /> 
<asp:Button ID= "Button2" runat= "server" Text= "新 增 作业 " onclick= "Button2_Click" 


/></td>< /tr> 
<tr id="lwwai" runat= "server"> 


<td colspan= "4"> 
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程序 5-62 实现 了 DropDownList 下 拉 列 表 中 课程 的 绑 定 。 
程序 5-62 ”作业 展示 页 面 中 的 课程 绑 定 (TeacherHomework. aspx. cs) 
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在 程序 5-62 中 通过 调用 IndexObject 的 方法 GetCoursebyTeacherID 来 获得 该 教师 
所 教 的 课程 。GetCoursebyTeacherID 方法 所 涉及 的 SQL 语句 如 下 所 示 。 


当 教 师 选 择 课 程 后 , 单 击 * 查 询 作 业 ” 按 钮 时 ,会 显示 该 教师 所 发 布 的 作业 ,如 程 
序 5-63 所 示 。 
程序 5-63 ”作业 展示 页 面 作业 绑 定 (TeacherHomework. aspx. cs) 


在 程序 5-63 中 通过 调用 IndexObject 的 方法 GetcoursebindbyTeacherIDand- 
courselID 来 获得 该 教师 对 所 选课 程 发 布 的 作 业 。 
GetcoursebindbyTeacherIDandcourseID 方法 所 涉及 的 SQL 语句 如 下 所 示 。 


单 击 每 个 作业 后 面 的 “修改 ”按钮 ,会 跳 转 到 作业 修改 页 ,如 图 5-33 所 示 。 
从 图 5-33 中 ,可 以 很 容易 地 看 出 , 它 是 由 作业 标题 ,作业 要 求 . 提 交 和 取消 4 个 部 分 
组 成 的 。 要 实现 这 样 的 效果 .其 前 台 代码 片段 如 程序 5-64 所 示 。 
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图 5-33 ”作业 修改 页 面 


程序 5-64 ”作业 修改 页 面 的 HTML 代码 (EditTeacherHomework. aspx) 
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页 面 初始 化 程序 如 程序 5-65 所 示 。 
程序 5-65 ”作业 修改 页 面 初始 化 代码 (EditTeacherHomework. aspx. cs) 


在 程序 5-65 中 通过 调用 IndexObject 的 方法 GetTeacherHomeworkContentby- 
HomeWorkID 来 获得 该 教师 对 所 选课 程 发 布 的 作业 标题 及 内 容 要 求 。 
GetTeacherHomeworkContentbyHomeWorkID 方法 所 涉及 的 SQL 语句 如 下 所 示 。 


修改 完毕 , 当 单 击 * 提 交 ” 按 钮 时 会 触发 Click 事件 ,该 事件 处 理 程 序 如 程序 5-66 
所 示 。 
程序 5-66 ”作业 修改 页 面 保存 修改 信息 代码 (EditTeacherHomework. aspx. cs) 
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在 程序 5-66 中 通过 调用 IndexObject 的 方法 UpdateTeacherHomeworkTitleAnd- 
Content 来 更 新 该 教师 对 所 选课 程 发 布 的 作业 标题 及 内 容 要 求 。 
UpdateTeacherHomeworkTitleAndContent 方法 所 涉及 的 SQL 语句 如 下 所 示 。 


作业 修改 页 面 的 完整 源 程序 在 \WEB\Teacher\ EditTeacherHomework. aspx 和 
\WEB\Teacher\ EditTeacherHomework. aspx. cs 文件 中 。 

单 击 每 个 作业 后 面 的 “删除 ”按钮 ,会 删除 该 条 作业 ,如 程序 5-67 所 示 。 

程序 5-67 删除 作业 代码 (TeacherHomework. aspx. Cs) 
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在 程序 5-67 中 通过 调用 IndexObject 的 方法 DeleteHomeWork 来 删除 该 条 作业 。 
DeleteHomeWork 方法 所 涉及 的 SQL 语句 如 下 所 示 。 


作业 展示 页 面 的 完整 源 程 序 在 \WEB\Teacher\ TeacherHomework. aspx 和 \WEB\ 
Teacher\ TeacherHomework. aspx. cs 文件 中 。 
单 击 作 业 的 标题 会 跳 转 到 学 生 回 答 作业 列表 的 页 面 ,如 图 5-34 所 示 。 


作业 的 情况 如 下 : 


| 3 | = 运程 教育 的 贬 点 
图 5-34 学 生 回答 作业 列表 


从 图 5-34 可 以 看 出 ,在 该 页 面 上 列 出 了 学 生 回答 该 条 作业 的 情况 ,包括 学 生 的 学 号 、 
学 生 的 姓名 及 查看 作业 三 个 部 分 。 要 实现 这 样 的 效果 ,其 代码 片段 如 程序 5-68 和 程 
序 5-69 所 示 。 

程序 5-68 ”学 生 回答 作业 列表 的 HTML 代码 (HomeWorkReply. aspx) 
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程序 5-69 ”学 生 回 答 作 业 列 表 的 后 台 代码 (HomeWorkReply. aspx. cs) 


在 程序 5-69 中 通过 调用 IndexObject 的 方法 GetAnswerListbyHomeWorkID 来 获 
得 学 生 回 答 该 条 作业 的 列表 。GetAnswerListbyHomeWorkID 方法 所 涉及 的 SQL 语句 


学 生 回答 作业 列表 的 完整 源 程序 在 \WEB\Teacher\ HomeWorkReply. aspx 和 
\WEB\Teacher\ HomeWorkReply. aspx. cs 文件 中 。 

单 击 图 5-34 中 作业 标题 时 会 跳 转 到 教师 批改 作业 的 页 面 ,如 图 5-35 所 示 。 

从 图 5-35 可 以 看 出 ,此 页 面 主要 由 作业 标题 .学 号 .姓名 .老师 布置 作业 的 要 求 ,学生 
回答 作业 的 内 容 、 教 师 的 评语 、 得 分 .提交 和 取消 9 个 部 分 组 成 。 要 实现 这 样 的 效果 ,其 前 
台 代 码 片断 如 程序 5-70 所 示 。 

程序 5-70 教师 批改 作业 页 面 的 HTML 代码 (StudentAnswer. aspx) 
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远程 教育 是 指 通过 音频 、 视 频 ( 直播 或 录 党 ) 及 包括 实时 和 非 实时 存 内 的 计算 机 技术 犯 培 

训 课程 传送 到 远 处 校园 外 ) 的 款 育 。 这 一 远程 教育 的 定义 三 包括 专门 在 校园 内 及 只 通过 书面 

本 全 人 证 天 全 林 育 下 全 四 攻 二 振作 术 用 捕 且 划 才 二 其 中 一 些 指导 也 有 可 能 是 通 
。 


图 5-35 教师 批改 作业 的 页 面 
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通过 接收 学 生 回答 作业 的 参数 AnswerID 来 初始 化 页 面 信息 ,包括 作业 标题 学 号 、 
姓名 、 作 业 要 求 及 学 生 回答 作业 的 内 容 等 几 个 部 分 ,如 程序 5-71 所 示 。 
程序 5-71 ”教师 批改 作业 页 面 的 初始 化 代码 (StudentAnswer. aspx. cs) 
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在 程序 5-71 中 通过 调用 IndexObject 的 方法 GetAnswerContentbyAnswerID 来 获 
得 学 生 回答 该 条 作业 的 相关 内 容 。GetAnswerContentbyAnswerID 方法 所 涉及 的 SQL 
语句 如 下 所 示 。 


批改 作业 的 提交 操作 实际 上 是 一 个 典型 的 数据 库 Update 操作 ,如 程序 5-72 所 示 。 
程序 5-72 ”教师 批改 作业 页 面 的 提交 代码 (StudentAnswer. aspx. cs) 
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在 程序 5-72 中 通过 调用 IndexObject 的 方法 UpdateTeacherCommentAndHome- 
workS 把 教师 对 学 生 作业 的 评语 及 作业 的 分 数 写 和 数据库 中 。UpdateTeacherCommen- 
tAndHomeworkS 方法 所 涉及 的 SQL 语句 如 下 所 示 。 


教师 批改 作业 页 面 的 完整 源 程 序 在 \WEB\Teacher\ StudentAnswer. aspx 和 \WEB 
\Teacher\ StudentAnswer. aspx. cs 文件 中 。 

到 此 为 止 , 单 击 “ 查 询 作 业 ” 按 钮 后 相关 的 操作 已 经 介绍 完毕 。 从 图 5-32 可 以 看 出 ， 
当 教 师 选 择 课程 后 , 单 击 “ 新 增 作业 "按钮 时 会 跳 转 到 新 增 作业 页 面 ,如 图 5-36 所 示 。 


到 .em 


一 [9 
图 5-36 教师 新 增 作业 页 面 


该 教师 可 以 对 该 课程 发 布 新 的 作业 ,包括 所 属 课程 .教师 姓名 、 作 业 标题 和 发 布 作业 
的 内 容 4 个 部 分 。 要 实现 这 样 的 效果 ,其 前 台 代 码 片断 如 程序 5-73 所 示 。 
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程序 5-73 ”教师 新 增 作业 页 面 的 HTML 代码 (AddTeacherHomeWork. aspx) 
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后 台 代码 类 似 于 教师 批改 作业 的 页 面 , 先 初始 化 显示 教师 所 选 的 课程 名 称 及 教师 的 
姓名 ,这 两 项 是 不 能 修改 的 。 通 过 调用 IndexObject 的 方法 GetTeacherNamebyTeach- 
erID 获得 教师 的 姓名 ,通过 调用 IndexObject 的 方法 GetCourseNameByCourseID 获得 课 
程 的 名 称 。 对 于 单 击 “ 提 交 ” 按 钮 ,实际 上 就 是 一 个 典型 的 数据 库 Insert 操作 ,通过 调用 
IndexObject 方法 的 InsertHomeWork 完成 新 增 作 业 的 功能 。 这 里 具体 的 代码 就 不 详细 
说 明了 。GetTeacherNamebyTeacherID、GetCourseNameByCourselD 和 InsertHome- 
Work 所 涉及 的 SQL 语句 如 下 所 示 。 


教师 新 增 作 业 页 面 的 完整 源 程序 在 \WEB\Teacher\ AddTeacherHomeWork. aspx 
和 \WEB\Teacher\ AddTeacherHomeWork. aspx. cs 文件 中 。 
作业 展示 模块 的 完整 源 程序 在 \WEB\Teacher 文件 夹 中 。 
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5.4.10 作业 展示 模块 (学 员 ) 


如 前 所 述 的 作业 展示 模块 (教师 ) ,教师 布置 完 作 业 后 ,学 员 就 需要 对 作业 进行 回答 
0 是 学 员 作业 展示 模块 的 功能 。 
学 员 作 业 展 示 模 块 的 主页 面 如 图 5-37 所 示 。 


当前 位 置 : >> 学 员 > 作业 展示 


站 sr 。 学 员 作业 展示 

。 思考 习题 请 过 择 查 齐 条 件 :加 教师 〇 课程 #5 各: [Teacherl 国 攻 可 

， 个 人 信息 设置 | yy 查询 结果 : 

2 作业 名 称 发 布 教 而 。 ”所 属 尝 程 发 布 时 间 是 本 回答 。 ”是否 批 网 
语文 教学 的 改革 Teacherl 语文 2008-1-21625:10 已 回答 未 批阅 


图 5-37 学 员 作业 展示 模块 的 主页 面 (Default. aspx) 


在 图 5-37 中 ,学 员 登 录 后 ,可 以 看 到 教师 布置 的 作业 及 学 员 回 答 的 情况 。 当 教师 布 
置 的 作业 ,学 员 没有 回答 ,在 “是 否 回 答 ” 列 上 显示 “未 回答 ”, 反 之 则 显示 “已 回答 ”; 当 学 员 
回答 完 作 业 后 ,等 待 教师 批阅 ,车 没有 批阅 , 则 “是 否 批 阅 " 列 显示 “未 评阅 ”, 反 之 则 显示 
in 学 员 做 作业 或 者 查看 教师 批阅 情况 ,直接 单 击 " 作 业 名 称 ” 列 下 的 标题 , 即 可 进 

答题 或 者 查看 批阅 情况 。 作 业 列 表 的 前 台 HTML 代码 如 程序 5-74 所 示 。 

程序 5-74 ”作业 列表 的 前 台 HTML 代码 (Default. aspx) 


<asp:GridView ID= "GV HomeWorkList" runat= "server" AllowPaging= "True" AutoGenerateCol - 
umns= "False" CssClass= "dataTable" PageSize="20" > 
<AlternatingRowStyle CssClass="DgAltItem" BackColor= # EEEEEE> < /Alternatin- 
gRowStyle> 
… 与 前 面 的 Gridview 控 件 的 样式 类 似 ) 
<HeaderStyle CssClass= "dataHeader" Height= 30px Font- Names= "Rrial”Horizonta- 
1Align= "Center" BackColor= "# DEF2FE"> < /Headerstyle> 
<Columns> 
<asp:TemplateField HeaderText=" 作 业 名 称 "> 
<ItemTemplate> 
<a id="Al" href= '<%#"Transfer.aspx?ColummId= "+ DataBinder.Eval (Contain - 
er.DataItem, 

"ColumnID") +" gHomeworkID =" + DataBinder. Eval (Container. DataItem, 
"HomeworkID")%>" class="navigator" runat="server"> <%#DataBinder.Eval (Container. 
DataItem, "Title")®%> 

</a> 

</ItemTemplate> 
< /asp:TemplateField> 
<asp:BoundField DataField- "UserName" HeaderText= "发 布 教师 " /> 
<asp:BoundField DataField= "CourseName" HeaderText= "所 属 课程 ” /> 
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<asp:BoundField DataField= "PublishTime” HeaderText= "发 布 时 间 ” /> 
<asp:BoundField DataField- "IsAnswer" HeaderText= "是 否 回答 ” /> 
<asp:BoundField DataField= "IsReply" HeaderText=" 是 否 批阅 ” /> 
< /Columns> 
< /asp:GridView> 


如 程序 所 示 ,“ 作 业 名 称 ” 列 是 一 个 模板 列 , 包 含 一 个 超级 链接 ,链接 的 地 址 为 Trans- 
fer. aspx 页 面 , 在 稍 后 会 讲 到 ,传递 的 参数 是 后 台 绑 定 的 。 其 他 的 列 都 是 绑 定 列 。 作 业 列 
表 后 台 绑 定 代码 如 程序 5-75 所 示 。 

程序 5-75 ”作业 列表 (GridView) 的 后 台 绑 定 (Default. aspx. cs) 


string StudentID= ((UserData)Session["Current_User"]) .UserID; 
String Parmas=new object[] { "", "", StudentID }; 

dt= IndexObject .GetHomeWorks (Parmas); 

GV_HomeWorkList .DataSource=dt .DefaultView; 

GV_HomeWorkList .DataBind (); 


得 到 作业 列表 是 由 IndexObject 类 的 GetHomeWorks 方法 ,该 方法 一 共有 三 个 参 
数 , 第 一 个 参数 是 课程 编号 ,第 二 个 参数 是 教师 编号 ,第 三 个 参数 是 学 员 编 号 。 该 处 的 程 
序 思想 跟前 面 讲 到 的 用 户 管理 和 课程 管理 类 似 , 初 始 化 列表 和 查询 共用 一 个 方法 ,这 里 
IndexObject 类 的 GetHomeWorks 方法 ,前 面 两 个 参数 是 给 查询 用 。 当 前 两 个 参数 都 为 
空 字符 串 时 ,表明 是 初始 化 作业 列表 ; 当 不 为 空 时 ,表明 是 根据 某 个 条 件 查询 ,得 到 满足 条 
件 的 作业 列表 ,这 个 在 稍 后 会 讲 到 。 所 以 在 这 里 ,前 两 个 参数 都 为 空 字符 串 ,第 三 个 参数 
是 学 员 编 号 ,可 以 从 Session["Current_User"] 获 得 。 得 到 作业 列表 后 .对 ID 为 GV_ 
HomeWorkList 的 Gridview 进行 绑 定 ( 注 : 学 员 登 录 时 ,学 员 的 基本 信息 会 存放 在 Ses- 
sion[ "Current_User" ] 中 )。 

GetHomeWorks 涉及 的 SQL 语句 如 下 所 示 。 


Select H. [ID] AS HomeworkID, H.ColumID, H.CourseID, C.CourseName, H.TeacherID, U.User- 
Name, H.Title, 

H.PublishTime, IsAnswer=case when len (A.Content)>0 then ' 已 回答 ' else ' 未 回答 ' 
end ， 

IsReply= case when len (A.TeacherComment)>0 then ' 已 批阅 ' else ' 未 批阅 ' end 

FROM HomeWork H 

LEFT JOIN Answer A ON H.ID= A.HomeworkID AND A.StudentID=@StudentID 

INNER JOIN Course C ON C.ID=H.CourseID 

INNER JOIN [User] U ON U.ID= H.TeacherID 
注 : len() 是 Sql Server 的 系统 函数 ,获取 字段 长 短 


该 SQL 语句 比较 复杂 ,IsAnswer 是 显示 学 员 是 否 回答 。 当 Answer 表 中 的 Content 
字段 长 度 大 于 0 时 .说 明 学 员 已 经 回答 ,IsAnswer 为 “已 回答 ”; 反 之 , 则 为 “未 回答 ”。Is- 
Reply 与 IsAnswer 字段 类 似 。HomeWork 表 与 Answer 表 之 间 是 左 连接 ,因为 若 为 内 连 
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接 时 , 当 学 员 没 有 回答 作业 ， Answer 表 中 的 HomeworkID 字段 没有 当前 作业 的 编号 , 导 
致 H.ID 二 A. HomeworkID 条 件 不 成 立 , 则 查询 为 空 。 若 为 左 连接 ,就 算 学 员 没 有 回答 ， 
没有 当前 作业 的 编号 ,也 不 影响 整个 作业 情况 的 查询 结果 。 而 Course 和 User 表 , 显 然 不 
会 出 现 这 种 情况 ,所 以 为 内 连接 。 

当 单 击 第 一 列 中 的 作业 标题 (例如 “语文 教学 的 改革 ”) 时 , 则 会 跳 转 到 Transfer. As- 
px 页面, 该 页 面 是 一 个 过 渡 页 ,处理 一 些 中 间 有 逻辑 ,代码 如 程序 5-76 所 示 。 

程序 5-76 Transfer. Aspx. cs 代码 


Protected void Page Load (object sender, EventArgs e) 
{ 
string HomeworkID= Request .QueryString["HomeworkID"] .Tostring (); 
string StudentID= ( (UserData) Session["Current User"]) .UserID; 
object[] Params=new object[] {HomeworkID, StudentID}; 
int mark= IndexObject .GetMark (Params); 


// 如 果 mark 为 1, 则 跳 转 到 ReadResult.aspx, 否 则 说 明 没有 回答 作业 , 跳 转 到 Add- 
Answer .aspx 


if (mark==1){ 


Response. Redirect ("ReadResult. aspx? HomeworkID="+ HomeworkID+" 
&StudentID= "+ StudentID); 


} 


else{ 


Response. Redirect (" AddAnswer. aspx? HomeworkID=" + HomeworkID+ 
"&StudentID= "+ StudentID); 


' 
} 


页 面 加 载 时 ,主要 执行 的 是 IndexObject 类 的 GetMark 方法 ,该 方法 的 参数 是 作业 编 
号 (HomeworkID)、 学 员 编 号 (StudentID) ,主要 功能 是 判断 学 员 是 否 回答 目前 作业 ,返回 
一 个 标志 位 。 当 学 员 没 有 回答 , 则 跳 转 到 回答 作业 页 面 (AddAnswer. aspx) ,和 否则 跳 转 到 
本 结果 页 面 (ReadResult. aspx) ,并 把 参数 都 带 过 去 。 所 以 用 户 实际 上 是 看 不 到 该 页 面 
的 。GetMark 方法 涉及 的 SQL 语句 如 下 所 示 。 


SELECT [ID] FROM Answer WHERE HomeworkID=@ HomeworkID and StudentID= StudentID 


下 面 先 分 析 一 下 回答 作业 页 面 (AddAnswer. aspx) ,如 图 5-38 所 示 。 

该 页 的 前 台 HTML 比较 简单 ,就 不 再 详细 介绍 。 页 面 初始 化 时 ,会 把 作业 的 相关 信 
息 显 示 在 页 面 上 ,实现 的 代码 如 程序 5-77 所 示 。 

程序 5-77 页 面 初始 化 代码 (AddAnswer. aspx. cs) 


Protected void Page Load (object sender, EventArgs e) 
1 
if (! IsPostBack) 
{ 
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主 文 孝 学 的 改革 
发 布 教师 : Tescherl 发 布 时 间 : 2008-12 16-25:1( 
作业 内 容 : 
语文 教学 的 改革 非常 重要 ， 大 家 要 努力 学 习 语 文教 学 的 改革 的 方法 。 内 | 
局 答 作 业 : 
EE 


图 5-38 回答 作业 页 面 (AddAnswer. aspx) 


string HomeworkID= Request .QueryString["HomeworkID"] .ToString (); 
object[] Parmas=new object [] { HomeworkID }; 

DataTable dt= IndexObject .GetHomeWorkByID (Parmas); 

this.lb title.Text=dt.Rows[0] ["Title"] .ToString()? 

this.lb_ teacher.Text=dt.Rows[0] ["UserName"] .Tostring(); 
this.lb time.Text=dt.Rows [0] ["PublishTime"] .ToString()? 
this.txt Content.Text=dt.Rows[0] ["Content"] .Tostring(); 


如 上 面 代码 所 示 ,第 一 次 加 载 页 面 时 ,首先 获取 查询 字符 串 HomeworkID 的 值 ,再 以 
该 值 为 参数 ,调用 IndexObject 类 的 GetHomeWorkByID 方法 。 该 方法 的 功能 是 根据 作 
业 编 号 ,获取 该 作业 的 基本 信息 ,再 对 页 面 上 的 控件 赋值 ,达到 初始 化 页 面 的 目的 。 
GetHomeWorkByID 方法 涉及 的 SQL 语句 如 下 所 示 。 


SELECT H.Title,U.UserName,H.Content,H.PublishTime FROM HomeWork H 
LEFT JOIN [User] U ON H.Teacherid=U. [ID] 
WHERE H. [ID]=@ HomeworkID 


单 击 “ 确 定 ” 和 “返回 ”按钮 .触发 submit_Click 和 Cancel_Click 事件 ,代码 如 程 
序 5-78 所 示 。 
程序 5-78 ”提交 事件 和 返回 事件 的 代码 (AddAnswer. aspx. cs) 


protected void submit Click (object sender, ImageClickEventArgs e) 
{ 
string HomeworkID= Request .QueryString["HomeworkID"] .ToString (); 
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提交 事件 主要 由 IndexObject 类 的 AddAnswer 方法 实现 ,该 方法 的 参数 为 作业 编号 
(HomeworkID) ,学 员 编 号 (StudentID) 和 回答 内 容 (Content) 。 涉 及 的 SQL 语句 如 下 所 示 。 


返回 事件 将 当前 页 面 跳 转 到 学 员 作业 展示 首页 (Default. aspx) 。 

接着 分 析 查 看 批阅 情况 页 面 ReadResult. aspx, 如 图 5-39 所 示 。 

该 页 的 前 台 HTML 比较 简单 ,就 不 再 详细 介绍 。 页 面 初始 化 时 ,会 把 作业 和 答题 情 
况 的 相关 信息 显示 在 页 面 上 .实现 的 代码 如 程序 5-79 所 示 。 

程序 5-79 查看 批阅 情况 页 面 (ReadResult. aspx. es) 代码 
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语文 教学 的 改革 
发 布 囊 师 : Tescherl 发 布 时 间 : 3008-1 3 1635:1( 


上 ET ET 


ET EEC 
| 恩 ， 非 党 赞成， 将 语文 教学 的 改革 进行 到 辰 ! 


回答 的 很 好 上 


图 5-39 查看 批改 情况 页 面 (ReadResult aspx) 


首先 ,调用 IndexObject 类 的 GetHomeWorkByID 方法 ,该 方法 在 前 面 已 经 讲 过 。 接 
着 调用 IndexObject 类 的 GetResult 方法 ,该 方法 的 参数 为 作业 编号 (HomeworkID) .学 
员 编号 (StudentID) ,功能 是 获取 学 员 答 题 和 教师 批阅 的 信息 。 这 两 个 方法 调用 完 后 ,把 
获取 的 信息 初始 化 到 页 面 的 控件 上 。GetResult 方法 涉及 的 SQL 语句 如 下 所 示 。 
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单 击 “ 返 回 " 按 钮 ,触发 返回 事件 , 跳 转 到 学 员 作业 展示 的 主页 面 。 

介绍 完 回答 作业 页 面 和 查看 结果 页 面 后 , 接 下 来 再 把 学 员 作业 展示 的 主页 面 (De- 
fault. aspx) 中 的 查询 功能 介绍 一 下 。 查 询 条 件 可 为 “教师 ”或 课程”。 当 选择 教师 查询 
时 ,只 能 选择 教师 ,如 图 5-40 所 示 ; 当选 择 课程 查询 时 ,只 能 选择 课程 ,如 图 5-41 所 示 。 
实现 动态 变化 的 效果 ,前 台 HTML 代码 如 程序 5-80 所 示 。 


请 选择 查询 条 件 : 回教 师 和 课程 教师 名 称 : | teacher 图 查询 


图 5-40 查询 条 件 为 教师 时 


请 选择 查询 条 件 : ”加 教师 加 课程 课程 名 称 : | 数学 国 查询 


图 5-41 查询 条 件 为 课程 时 
程序 5-80 ”查询 的 前 台 HTML(Default. aspx) 


<table> 
<tr> 
<td align= "right" width= "15$"> 请 选择 查询 条 件 : < /td> 
<td align= "left" style= "width: 9$ "> 
< asp: RadioButtonList ID="rbl Condition" runat="server" AutoPostBack=" 
true' 
RepeatDirection="Horizontal" OnSelectedIndexChanged="rbl] Condition Se- 
lectedIndexChanged"> 
<asp:ListItem Value="0" Selected= "True"> 教 师 < /asp:ListItem> 
<asp:ListItem Value= "1"> 课 程 < /asp:ListItem> 
</asp:RadioButtonList>< /td> 
<td align= "right"><asp:Label ID= "txt_params"” runat= "server"” Text= "课程 名 
称 :"></asp:Label> 
</td> 
<td align= "left" ><asp:DropDownList ID= "ddl TeaORCourse" runat="server"> 
</asp:DropDownList>< /td> 
<td align="left"><asp:Button ID="select" runat="server" Text= "查询 " on - 
Click="select Click" />< /td> 
</tr> 
</table> 


为 了 实现 查询 条 件 动态 变化 .必须 设置 ID 为 rbl_Condition 的 RadioButtonList 的 属 
性 AutoPostBack 王 "True", 使 得 rbl_Condition 中 选项 更 改 时 ,能 自动 提交 页 面 。 页 面 主 
要 有 两 个 事件 ，RadioButtonList 的 更 改选 定 索 引 触发 的 事件 rbl_Condition_SelectedIn- 
dexChanged, 其 实现 如 程序 5-81 所 示 。 

程序 5-81 rbl_Condition_SelectedIndexChanged 的 后 台 代码 (Default. aspx. cs) 
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当 rbl_Condition 的 选项 更 改 时 ,触发 的 rbl_Condition_SelectedIndexChanged 事件 
的 功能 如 下 : 若 当前 rbl_Condition 的 值 为 0, 说 明 Condition 选择 的 是 “教师 ”, 则 将 ID 为 
txt_params 的 Label 赋值 为 “教师 名 称 :”, 并 由 UserManageObject 类 的 GetTeachers 获 
取 所 有 教师 的 列表 .并 以 该 列表 为 数据 源 , 将 ID 为 ddl_TeaORCourse 下 拉 框 进行 数据 绑 
定 ;当前 rbl_Condition 的 值 为 1 ,说明 Condition 选择 的 是 “课程 ”, 则 将 ID 为 txt_params 
的 Label 赋值 为 “课程 名 称 :”, 并 由 CourseManageObject 类 的 GetCourses 获取 所 有 课程 
的 列表 ,并 以 该 列表 为 数据 源 , 将 ID 为 ddl_TeaORCourse 下 拉 框 进行 数据 绑 定 。 实 现 了 
动态 变化 查询 条 件 。GetTeachers 和 GetCourses 方法 涉及 的 SQL 语句 前 面 已 经 讲 过 ,在 
这 里 不 再 讲述 。 

单 击 “ 查 询 ” 按 钮 触发 事件 select_Click ,其 实现 代码 如 程序 5-82 所 示 。 

程序 5-82 ”select_Click 的 后 台 代 码 ( 位 于 Default. aspx. cs 中 ) 
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查询 时 ,首先 根据 rbl_Condition 的 值 判断 查询 条 件 是 教师 还 是 课程 ,若是 教师 , 则 调 
用 IndexObject 的 GetHomeWorks 方法 .教师 姓名 (ddl_TeaORCourse. SelectedValue) 、 
学 员 编号 (StudentID) ,得 到 满足 条 件 的 作业 列表 ; 若 为 课程 .也 是 调用 IndexObject 的 
GetHomeWorks 方法 ,不 过 参数 为 课程 名 称 (ddl_TeaORCourse. SelectedValue) 和 学 员 
编号 (StudentID) ,得 到 满足 条 件 的 作业 列表 。GetHomeWorks 方法 涉及 的 SQL 语句 前 
面 已 经 讲 过 ,不 过 是 没有 条 件 约束 ( 即 WHERE 语句 ), 则 在 刚 提 到 的 两 个 GetHome- 
Works 所 涉及 的 SQL 语句 分 别 比 前 面 讲 到 的 SQL 多 了 一 个 查询 条 件 ( 即 WHERE 条 
件 ) 而 已 。 
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5.4.11 思考 习题 模块 (教师 端 . 学 员 端 ) 
该 模块 与 作业 展示 模块 (教师 端 .学 员 端 ) 类 似 ,本 书 不 作 曾 述 。 
5.4.12 友情 链接 模块 


友情 管理 模块 也 是 管理 员 才 具有 权限 操作 的 模块 。 具 有 的 操作 权限 为 删除 、 修 改 和 
增加 。 该 模块 主要 由 LinkManage 文件 夹 下 的 链接 管理 首页 (Default. aspx) ,增加 链接 页 
面 (AddLink. aspx) 和 修改 链接 页 面 (UpdateLink. aspx) 这 三 个 页 面 实现 。 该 模块 本 书 不 
打算 详 述 ,因为 其 前 台 代码 和 后 台 代码 与 课程 管理 类 似 。 下 面 简单 介绍 一 下 用 到 的 核心 
方法 及 SQL 语句 。 友 情 链接 的 首页 如 图 5-42 所 示 。 


当前 位 置 : >> 系统 管理 员 > 友情 链接 


9 友情 链接 管理 页 


链接 标题 链接 地 址 加 入 时 间 
中 国 石油 大 学 dt 京 ) httpyrwwcopeducn 2008.1.611:1658 (个 改 ] 才 厦 访 


5-42 友情 链接 管理 的 首页 (Default. aspx) 
列表 初始 化 ( 即 GridView 的 绑 定 ) 由 FriendshipLinkManageObject 类 的 GetLinks 
方法 实现 ,该 方法 没有 参数 。 涉 及 的 SQL 语句 如 下 所 示 。 
SELECT [ID],LinkTitle,LinkUrl, AddTime FROM FriendshipLink 


修改 事件 由 FriendshipLinkManageObject 类 的 UpdateLink 方法 实现 ,该 方法 的 参 
数 为 链接 编号 (LinkID) ,链接 标题 (LinkTitle) 和 链接 地 址 (LinkUrl) 。 涉 及 的 SQL 语句 
如 下 所 示 。 

UPDRTE FriendshipLink 

SET LinkTitle=@LinkTitle ,LinkUrl=@LinkUrl 
WHERE ID=@LinkID 

删除 事件 由 FriendshipLinkManageObject 类 的 DeleteLink 方法 实现 ,该 方法 只 有 一 

个 参数 链接 编号 (LinkID)。 涉 及 的 SQL 语句 如 下 所 示 。 


FROM FriendshipLink WHERE [ID]=@LinkID 


新 增 链接 事件 由 FriendshipLinkManageObject 类 的 AddLink 方法 实现 ,该 方法 的 参 
数 为 链接 标题 (LinkTitle) 和 链接 地 址 (LinkUrl) 。 涉 及 的 SQL 语句 如 下 所 示 。 
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友情 链接 管理 模块 的 所 有 页 面 都 在 系统 根 目录 下 的 LinkManage 文件 夹 中 。 
5.4.13 个 人 信息 设置 模块 


个 人 信息 设置 有 些 方面 类 似 于 用 户 注册 ,但 是 又 有 不 同 于 用 户 注册 的 方面 。 图 5-43 
是 设计 的 个 人 信息 设置 的 页 面 ,以 不 同 身份 的 用 户 进入 管理 平台 以 后 ,都 会 有 个 人 信息 设 
置 的 管理 模块 ,这 就 要 对 角色 加 以 区 分 。 


当前 位 置 ; >> 学 员 > 个 人 信息 设置 


9 个 人 沪 息 设置 


用户 各 : 


| 学 生 b 
aa@163 com 
[az 


Imsn111 


9 


区 下 
5-43 个 人 信息 设置 


从 图 5-43 可 以 看 出 .个 人 信息 设置 与 注册 的 最 大 不 同 点 是 它 把 用 户 的 原 有 信息 在 初 
始 阶段 就 显示 出 来 了 ,要 实现 这 样 的 效果 ,其 前 台 代 码 片段 如 程序 5-83 所 示 。 
程序 5-83 个 人 信息 设置 页 面 的 HTML 代码 (perinformation. aspx) 


HE 


第 5 章 ”远程 教育 系统 实例 


当 用 户 登 录 以 后 ,个 人 信息 设置 页 面 中 会 显示 用 户 原 有 的 信息 ,要 实现 这 样 的 功能 就 
需要 在 页 面 初 始 化 时 绑 定 数据 ,通过 用 户 登 录 以 后 保存 在 Session["Current_User"] 中 的 
UserID 来 获得 用 户 的 基本 信息 。 程 序 代 码 如 程序 5-84 所 示 。 

程序 5-84 个 人 信息 设置 页 面 初始 化 的 后 台 代 码 (perinformation. aspx. cs) 
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通过 调用 IndexObject 的 方法 GetPerInformation 来 显示 用 户 的 原 有 信息 。GetPer- 
Information 方法 所 涉及 的 SQL 语句 如 下 所 示 。 


个 人 信息 更 新 的 代码 类 似 于 用 户 注册 ,只 不 过 它 是 一 个 典型 的 数据 库 Update 操作 ， 
通过 调用 checklogin 的 方法 UpdateUser 来 更 新 用 户 信 息 。UpdateUser 方法 所 涉及 的 
SQL 语句 如 下 所 示 。 
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个 人 信息 设置 模块 的 完整 源 程 序 在 \WEB\ IndividualInformation\ perinformation. 
aspx 和 \WEB\ IndividualInformation\ perinformation. aspx. cs 文件 中 。 
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精心 制作 好 了 网 站 ,下 一 步 的 工作 就 是 要 在 一 台 工 作 稳定 的 服务 器 上 把 它 发 布 出 来 。 
在 网 络 上 启用 了 Web 服务 器 后 ,就 可 以 使 用 该 服务 器 将 精心 制作 的 网 页 提供 给 Internet 
上 的 用 户 浏览 。SQL Server 2000 提供 了 在 服务 器 的 系统 上 运行 的 服务 器 软件 和 在 客户 
端 运行 的 客户 端 软 件 , 连 接客 户 和 服务 器 计算 机 的 网 络 软件 则 由 Windows 系统 提供 。 
SQL Server 2000 数据 库 系统 的 服务 器 运行 在 Windows NT/2000 系统 上 ,负责 创建 、 维 
护 表 和 索引 等 数据 库 对 象 ,确保 数据 的 完整 性 和 安全 性 ,能 够 在 出 现 各 种 错误 时 恢复 数 
据 。 将 数据 从 服务 器 检索 出 来 后 可 以 生成 备份 ,以 便 在 本 地 保留 ,也 可 以 进行 操作 。SQL 
Server 2000 建立 于 Microsoft Windows NT/2000 的 可 伸缩 性 和 可 管理 性 之 上 ,提供 了 功 
能 强大 的 客户 服务 器 平台 。 本 章 介绍 在 Windows 2000 操作 系统 中 如 何 安装 和 配置 Web 
服务 器 和 数据 库 服务 器 。 


6.1 IIS 配置 与 管理 


随 着 Internet 的 发 展 ,传统 的 局 域 网 资源 共享 方式 已 不 能 满足 人 们 对 信息 的 需求 , 创 
建 Internet 信息 服务 器 无 疑 是 人 们 的 最 佳 选择 。 信 息 服 务 器 包括 Web FTP 和 SMTP 虚 
拟 服务 器 三 个 方面 ,不 但 实现 了 公司 内 部 网 络 的 Intranet 信息 服务 ,而 且 还 可 以 使 公司 网 
络 连接 到 Internet 上 ,为 公司 的 远程 客户 或 业务 伙伴 提供 信息 服务 。 


6.1.1 Internet Information Server 5.0 简介 


IIS 5.0 与 Windows 2000 捆绑 在 一 起 ,从 而 集成 了 Windows 2000 的 一 些 先 进 特 性 。 
安装 Windows 2000 时 可 以 选择 安装 该 组 件 ,也 可 以 在 安装 Windows 2000 之 后 ,通过 “ 添 
加 /删除 组 件 ” 工 具 进 行 安装 。 与 IIS 4.0 相 比 ,IIS 5.0 的 改进 在 于 可 靠 性 、 安 全 性 、 性 能 、 
管理 ,编程 和 Internet 标准 支持 等 方面 的 增强 。 例 如 在 性 能 上 ,IIS 5. 0 增强 了 对 虚拟 服 
务 器 数量 的 支持 :IIS 4. 0 服务 器 可 以 支持 大 约 250 个 虚拟 Web 站 点 ,IIS 5. 0 则 可 以 支持 
数 千 个 站 点 。 

IIS 5.0 的 可 靠 性 改进 表现 在 : 提供 了 更 多 的 Web 进程 保护 功能 ,如 图 6-1 所 示 。 
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Web 应 用 进程 和 IIS 核心 服务 进程 (Internet Service) 隔 离开 来 ,IIS 核心 服务 进程 在 单独 
的 内 存 空 间 内 ,Web 应 用 进程 可 以 在 共享 地 址 空间 的 进程 池 (Pooled Process) 中 ,也 可 以 
单独 隔离 (Isolated Process) 到 另 一 个 地 址 空间 ,因此 能 独立 停止 和 重 起 每 个 进程 ,从 而 提 
高 了 Web 服务 器 的 可 靠 性 和 稳定 性 ,但 进程 隔离 也 损耗 了 一 部 分 系统 性 能 。 在 安全 性 方 
面 ,IIS 5.0 可 以 使 用 Windows 2000 活动 目录 功能 实现 用 户 身份 的 验证 ,也 可 以 结合 使 用 
证 书 和 活动 目录 来 验证 用 户 。 此 外 ,IIS 5.0 也 加 快 了 对 进程 外 应 用 的 执行 速度 及 ADO 
数据 库 访问 的 效率 。 
Main Process 了 Pooled Process Jsolated Process 


Inetin DLLHostexe DLLHost.exe 
(Intemet Se! 


Application1l Hi ority Application 


Application2 


Application3 


Application4 
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在 Windows 2000 高 级 服务 器 和 数据 中 心服 务 器 中 ,IIS 5.0 和 群集 服务 功能 紧密 集成 ， 
通过 载 量 平衡 服务 可 以 很 方便 地 建立 多 机 均 载 的 Web 网 站 。IIS 5. 0 支持 动态 服务 器 页 面 
(ASP) 的 最 新 版 3.0。 与 以 前 的 版 本 相 比 ,ASP 3. 0 提高 了 效率 ,功能 也 更 强 , 还 提供 了 和 
XML 的 集成 ,同时 也 可 以 用 ADSI 2. 0 对 Windows 2000 Active Directory 进行 操作 。 

另外 ,IIS 5.0 还 具有 以 下 具体 特性 。 

(1) 摘要 式 身份 验证 。 人 允许 跨 代理 服务 器 和 防火 墙 对 用 户 进行 安全 和 严格 的 身份 验 
证 。 另 外 ,还 可 进行 匿名 、 基 本 验证 及 集成 Windows 身份 验证 ,在 Windows NT 下 称 为 
质询 /响应 身份 验证 和 NTLM 身份 验证 。 

(2) 安全 通信 。 安 全 套 接 字 协议 层 (SSL) 3. 0 和 传输 协议 层 安全 (TLS) 提 供 了 一 种 
客户 端 与 服务 器 之 间 进 行 信息 交换 的 安全 方式 。 另 外 ,SSL 3.0 和 TLS 还 为 服务 器 提供 
了 一 种 在 用 户 登 录 服 务 器 之 前 对 客户 端 进行 验证 的 方法 。 在 IIS 5.0 中 ,ISAPI 和 Active 
Server Pages 都 可 以 访问 客户 证 书 , 以 便 编程 人 员 通 过 其 站 点 跟踪 用 户 。 同 时 ,IIS 5.0 
还 可 以 将 客户 证 书 映射 为 Windows 用 户 账 户 ,以 便 管 理 员 可 以 根据 客户 证 书 控制 对 系统 
资源 的 访问 。 

(3) 服务 器 网 关 加 密 。 服 务 器 网 关 加 密 (SGC) 是 SSL 的 扩展 ,允许 使 用 IIS 的 出 口 
版 的 金融 系统 采取 加 密 性 能 更 高 的 128 位 加 密 。 虽 然 IIS 5.0 中 已 内 置 了 SGC 功能 ,但 
使 用 SGC 时 仍然 需要 特殊 的 SGC 证 书 。 

(4) 安全 向 导 。Web 服务 器 证 书 向 导 、 权 限 向 导 和 CTL 向 导 简 化 了 服务 器 配置 的 复 

(5) IP 地 址 及 Internet 域 限 制 。 可 以 授予 或 拒绝 单 台 计算 机 、 计 算 机 组 或 者 整个 域 
对 本 机 Web 站 点 的 访问 。 

(6) 兼容 Kerberos5 身份 验证 协议 。IIS 已 完全 集成 了 Windows 2000 中 实现 的 


279 


网 站 建设 实用 教程 


Kerberos5 验证 协议 ,从 而 允许 用 户 在 运行 Windows 的 计算 机 之 间 传 递 验证 凭据 。 

(7) 证 书 存储 。IIS 证 书 存 储 目前 已 与 Windows CryptoAPI 存储 集成 在 一 起 。Win- 
dows Certificate Manager 提供 单一 入 口 ,允许 用 户 存储 、 备 份 和 配置 服务 器 证 书 。 

(8) Fortezza。1IIS 5.0 支持 称 为 Fortezza 的 美国 政府 安全 标准 。 该 标准 通过 一 种 加 
密 机 制 保证 消息 的 安全 性 、 完 整 性 、 验 证 .以 及 对 消息 `. 组 件 和 系统 的 访问 控制 。 

(9) 重新 启动 IS。 在 IIS 5.0 中 ,可 以 停止 并 重新 启动 所 有 IIS 管理 单元 中 的 Inter- 
net 服务 ,这 使 得 在 应 用 程序 运行 不 正常 或 变 得 不 可 用 时 无 需 重新 启动 计算 机 。 

(10) 进程 账户 。 进 程 账户 是 IIS 5. 0 中 的 一 个 新 特性 , 它 将 字段 添加 到 W3C 扩充 日 
志文 件 , 以 记录 关于 Web 点 如 何 使 用 服务 器 上 CPU 资源 的 信息 。 这 些 信息 用 于 确定 站 
点 是 否 在 使 用 不 相称 的 过 多 CPU 资源 或 检测 故障 脚本 及 CGI 进程 。 进 程 账户 仅 用 于 
Web 站 点 ,不 提供 单个 应 用 程序 使 用 CPU 的 详细 细节 及 仅 关 于 进程 外 应 用 程序 的 日 志 
信息 。 从 进程 账户 获得 的 信息 可 用 来 决定 是 否 应 该 启用 Web 站 点 上 的 进程 限制 。 

(11) 进程 限制 。 可 以 限制 CPU 在 处 理 单个 Web 站 点 进程 外 的 及 应 用 程序 的 时 间 
百分比 。 另 外 ,还 可 以 终止 和 重新 启动 运行 失常 的 进程 。 

(12) 改进 的 自 定义 错误 消息 。 当 Web 站 点 出 现 HTTP 错误 时 ,目前 管理 员 可 以 向 
用 户 发 送 消息 。 可 以 使 用 IIS 5. 0 提供 的 自 定义 错误 消息 ,也 可 创建 自己 的 错误 消息 。 

(13) 配置 选项 。 可 以 在 站 点 、 目 录 或 文件 级 别 设置 读 取 、 写 入 、 执 行 、 脚 本 及 Front- 
Page Web 操作 的 权限 。 

(14) 远程 管理 。IIS 5. 0 包含 了 一 些 基于 Web 的 管理 工具 ,可 以 从 任何 平台 的 几乎 
所 有 浏览 器 上 进行 Internet 服务 的 远程 管理 。 利 用 IIS 5.0, 可 以 设置 称 为 “操作 员 ” 的 管 
理 账 户 ,使 之 具备 一 定 的 Web 站 点 管理 权限 ,帮助 分 担 一 部 分 管理 任务 。 

(15) 标准 的 支持 。IIS 5. 0 符合 HTTP 1. 1 标准 ,包括 PUT 和 DELETE 等 功能 及 
自 定义 HTTP 错误 消息 的 能 力 , 并 支持 自 定义 的 HTTP 头 。 

(16) 多 个 站 点 ,一 个 IP 地 址 。 由 于 支持 主机 头 ,因此 ,可 以 用 一 个 IP 地 址 在 运行 
Windows 2000 的 单 台 服务 器 上 维护 多 个 Web 站 点 。 这 对 于 Internet 服务 提供 商 及 维护 
多 个 站 点 的 公司 非常 有 用 。 

(17) Web 分 布 式 创作 与 版 本 管理 (WebDAV)。 人 允许 远程 作者 通过 HTTP 连接 创 
建 、 移 动 或 删除 服务 器 上 的 文件 ,文件 属性 .目录 和 目录 属性 。 在 服务 器 上 设置 WebDAV 
发 布 目录 与 设置 虚拟 目录 一 样 简单 。 设 置 好 了 发 布 目 录 后 ,具有 正确 权限 的 用 户 就 可 以 
将 文档 发 布 到 服务 器 上 并 处 理 目录 中 的 文件 。 

(18) PICS 分 级 。 可 以 将 PICS 分 级 应 用 于 内 容 仅 适合 于 成 人 的 站 点 。 

(19) FTP 重新 启动 。 如 果 在 数据 传输 中 出 现 中 断 , 则 可 以 恢复 FTP 文件 下 载 ,而 不 
必 再 次 下 载 整 个 文件 。 

(20) HTTP 压缩 。 可 以 更 快 地 在 Web 服务 器 与 启用 了 压缩 的 客户 之 间 进 行 页 面 传 
输 。 压 缩 和 缓存 静态 文件 并 对 动态 生成 的 文件 按 需 进行 压缩 。 


6.1.2 安装 Internet 信息 服务 
在 安装 Windows 2000 时 ,如 果 用 户 选择 了 安装 IIS 5. 0, 系 统 就 会 自动 创建 一 个 
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HTTP 站 点 和 一 个 FTP 站 点 。IIS 预 设 的 Web 站 点 和 FTP 站 点 发 布 目录 也 被 称 为 主 目 
录 , 其 Web 站 点 主 目录 的 路 径 是 \Inetpub\WWWroot,FTP 站 点 主 目录 的 路 径 是 \ Inet- 


pub\FTProot。 


对 于 Web 站 点 来 说 ,如 果 本 地 网 络 中 带 有 诸如 DNS 这 样 的 命名 系统 ,那么 其 他 访问 
者 只 需 在 浏览 器 地 址 下 拉 列 表 框 中 输入 计算 机 名 就 可 以 访问 相应 的 站 点 。 但 是 ,如 果 本 
地 网 络 中 没有 诸如 DNS 这 样 的 命名 系统 ,那么 其 他 访问 者 必须 在 地 址 下 拉 列 表 框 中 输入 


计算 机 的 IP 地 址 才能 访问 。 


对 于 FTP 站 点 来 说 ,如 果 本 地 网 络 中 带 有 诸如 DNS 这 样 的 命名 系统 ,那么 其 他 访问 
者 需 在 地 址 下 拉 列 表 框 中 输入 *FTP: // 用 户 的 计算 机 名 ”, 就 可 以 访问 站 点 。 但 是 ,如 果 
本 地 网 络 中 没有 诸如 DNS 这 样 的 一 个 命名 系统 ,那么 其 他 访问 者 必须 在 地 址 下 拉 列 表 框 
中 输入 “FTP// 用 户 计算 机 的 IP 地 址 ”才能 访问 。 

如 果 用 户 在 安装 Windows 2000 时 没有 选择 安装 IIS 5.0, 并 需要 创建 Internet 信息 
服务 器 , 则 可 使 用 控制 面板 中 的 “添加 /删除 程序 ”向导 来 安装 此 组 件 , 过 程 如 下 。 

(1) 打开 “开始 "菜单 ,选择 “设置 "一 “控制 面板 "命令 ,打开 “控制 面板 ”窗口 ,双击 “ 添 
加 /删除 程序 ”图 标 ,打开 “添加 /删除 程序 ”窗口 。 

(2) 在 左边 列表 栏 中 , 单 击 “ 添 加 /删除 Windows 组 件 ” 按 钮 ,然后 单 击 “ 组 件 ”按钮 ， 
安装 程序 开始 启动 .启动 之 后 打开 “Windows 组 件 向 导 ” 对 话 框 (如 图 6-2 所 示 )。 


Tindovs 组 件 
可 以 添加 或 删除 Windows XP 的 组 件 。 


2 aaanesenan 


= 


口 千 ouuook Express 
|D 四 minaors medis Payer 


EEC 
0.0 上 
0.0 上 


o0m | 


描述 : 包括 Web 和 i 以 及 对 FrontPage、 事 务 处 理 、Active 
Server Pages 库 连 援 的 支持 。 
所 需 磁 盆 宝 间 : 56.6 MB ET 
可 用 磁盘 空间 12247.4 NB EL 
[mA uA 取消 


图 6-2 Windows 组 件 窗口 


(3) 选中 “组 件 ” 列 表 框 中 的 “Internet 信息 服务 (IIS)” 复 选 框 。 
(4) 单 击 “ 下 一 步 "按钮 ,系统 即 可 进行 IIS 5.0 的 安装 ,同时 打开 “正在 配置 组 件 ” 对 


话 框 (如 图 6-3 所 示 )。 


(5) IIS 5.0 安装 完成 之 后 ,向 导 进入 最 后 一 步 , 单 击 “ 确 定 ” 按 钮 即 可 。 


6.1.3 创建 Web 站 点 


创建 Web 服务 器 和 FTP 服务 器 是 Internet 信息 服务 器 最 重要 的 内 容 , 通 过 Web 服 
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Windows 组 件 向 导 


七 请 稍 候 ,安装 程序 正在 配置 组 件 。 所 花 时 间 取 决 于 先 定 的 组 件 。 


状态 正在 完成 索引 服务 的 配置 - 


6-3 “正在 配置 组 件 " 对 话 框 


务 器 ,用 户 可 以 有 效 直 观 地 将 企业 信息 发 布 给 企业 内 部 用 户 和 Internet 远程 用 户 ;通过 
FTP 服务 器 ,可 实现 服务 器 和 客户 机 之 间 的 快速 文件 传输 。 安 装 好 IIS 之 后 ,会 自动 创建 
一 个 默认 的 Web 站 点 和 一 个 默认 的 FTP 站 点 ,供用 户 快速 发 布 内 容 。 用 户 也 可 自己 创 
建 Web 站 点 和 FTP 站 点 ,以 扩大 和 丰富 自己 的 Web 服务 器 和 FTP 服务 器 上 的 信息 。 

通常 情况 下 ,每 一 个 Web 或 FTP 站 点 在 内 容 上 都 有 自己 的 主题 ,以 便 其 他 访问 者 快 
速 进 行 信息 查找 。 如 果 有 多 个 主题 的 信息 文件 需要 在 网 络 上 发 布 ,应 在 服务 器 上 创建 不 
同 的 Web 或 者 FTP 站 点 ,分 别 进行 信息 发 布 。 

要 创建 Web 或 FTP 站 点 ,可 参照 下 面 的 步骤 。 站 点 创建 好 之 后 ,就 可 通过 创建 主 目 
录 和 虚拟 目录 来 将 具有 相关 主题 的 信息 文件 发 布 到 网 上 。 

(1) 打开 Internet 服务 管理 器 窗口 ,展开 “Internet 信息 服务 "节点 和 服务 器 节点 。 

(2) 如 果 要 创建 Web 站 点 , 右 击 服务 器 节点 ,从 弹出 的 快捷 菜单 中 选择 “新 建 ”一 
“Web 站 点 ”命令 ,打开 “Web 站 点 创建 向 导 ? 对 话 框 。 

(3) 单 击 * 下 一 步 ?按钮 ,打开 “Web 站 点 说 明 "对 话 框 ,在 “说 明 "文本 框 中 输入 站 点 
说 明 。 

(4) 单 击 * 下 一 步 ? 按 钮 ,打开 *IP 地 址 和 端口 设置 ?对 话 框 ,在 “输入 Web 站 点 使 用 的 
IP 地 址 ?下拉 列表 中 选择 或 直接 输入 IP 地 址 ;在 * 此 Web 站 点 应 使 用 到 的 TCP 端口 " 文 
本 框 中 输入 TCP 端口 值 ,默认 值 为 89。 如果 有 主机 标 头 ,可 在 “此 站 点 的 主机 标 头 ”文本 
框 中 输入 标 头 ;默认 为 没有 。 

(5) 单 击 “ 下 一 步 ” 按 钮 ,打开 “Web 站 点 主 目录 ”对 话 框 ,在 “路 径 ” 文本 框 中 输入 主 
目录 的 路 径 或 单 击 “ 浏 览 ” 按 钮 选择 路 径 。 

(6) 单 击 “ 下 一 步 ” 按 钮 .打开 “Web 站 点 访问 权限 ”对 话 框 ,在 “允许 下 列 权限 ”选项 区 
域 中 设置 主 目录 的 访问 权限 。 选 中 “ 读 取 ” 复 选 框 , 则 只 给 访问 者 读 取 权限 ;选中 “ 写 人 " 复 
选 框 , 则 访问 者 有 修改 权限 。 一 般 情 况 下 ,应 禁用 “ 写 入 ” 复 选 框 ,不 给 访问 者 授予 修改 
权限 。 
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(7) 单 击 “ 下 一 步 "按钮 ,打开 “您 已 成 功 完成 Web 站 点 创建 向 导 ” 对 话 框 。 单 击 “ 完 
成 "按钮 ,完成 站 点 创建 。 


6.1.4 创建 虚拟 目录 


虚拟 目录 是 指 除 了 主 目录 以 外 的 其 他 站 点 发 布 目 录 。 在 客户 浏览 器 中 ,虚拟 目录 就 
像 位 于 主 目录 中 一 样 .但 它 物理 上 并 不 包含 在 主 目录 中 。 当 站 点 太 复 杂 , 或 决定 在 网 页 中 
使 用 脚本 或 应 用 程序 时 ,就 需要 为 要 发 布 的 内 容 创建 虚拟 目录 。 

要 创建 虚拟 目录 ,可 参照 下 面 的 步骤 。 

(1) 打开 Internet 服务 管理 器 窗口 ,在 创建 好 的 Web 站 点 上 单 击 右键 ,选择 “新 建 ” 
一 “虚拟 目录 ”命令 ,打开 “虚拟 目录 创建 向 导 ” 对 话 框 ,然后 单 击 * 下 一 步 "按钮 ,打开 “虚拟 
目录 别名 ”对 话 框 。 

(2) 在 “别名 ”文本 框 中 输入 用 于 获得 此 Web 虚拟 目录 访问 权限 的 别名 。 输 入 别名 
后 , 单 击 “下 一 步 "按钮 ,打开 “Web 站 点 内 容 目 录 ” 对 话 框 。 

(3) 如 果 用 户 知 道 目 录 路 径 , 可 直接 在 “目录 ”文本 框 中 输入 目录 路 径 ,否则 单 击 “ 浏 
览 ” 按 钮 ,打开 “浏览 文件 夹 ” 对 话 框 ,选择 目录 路 径 。 

(4) 单 击 “ 下 一 步 ” 按 钮 ,打开 “访问 权限 ”对 话 框 。 在 “允许 下 列 权限 ”选项 区 域 中 ,用 
户 可 以 为 此 目录 设置 访问 权限 。 

(5) 访问 权限 设置 完成 后 , 单 击 " 下 一 步 ” 按 钮 ,打开 “您 已 成 功 完成 虚拟 目录 创建 向 
导 ” 对 话 框 。 单 击 “ 完 成 "按钮 ,虚拟 目录 创建 完成 。 

对 于 Web 站 点 来 说 ,如 果 需 要 建立 多 个 虚拟 目录 ,上 面 的 方法 就 显得 不 太 方便 。 这 
时 ,用 户 可 以 直接 通过 设置 文件 的 Web 共享 属性 来 快速 创建 虚拟 目录 ,具体 操作 步 又 
如 下 。 

(1) 打开 “我 的 电脑 "或 “资源 管理 器 "窗口 , 右 击 要 共享 的 文件 夹 , 从 弹出 的 快捷 菜单 
中 选择 “属性 ”命令 ,打开 文件 夹 属性 对 话 框 ,然后 选择 Web 共享 "选项 卡 (如 图 6-4 
所 示 )。 

(2) 选择 “共享 文件 夹 " 单 选 按钮 ,此 时 会 弹出 “编辑 别名 ”对话 框 (如 图 6-5 所 示 )。 

(3) 在 “别名 ”文本 框 中 输入 该 目录 的 别名 。 按 照 默认 规定 ,如 果 没 有 更 改 信息 ,计算 
机 将 指定 该 目录 名 为 匿名 。 在 “访问 权限 ”选项 区 域 中 .通过 启用 复 选 框 来 设置 虚拟 目录 
的 访问 权限 ,例如 选中 “脚本 资源 访问 " 复 选 框 , 则 允许 访问 者 访问 脚本 资源 。 

(4) 在 “应 用 程序 权限 ”选项 区 域 中 ,通过 选择 单 选 按 钮 来 设置 目录 中 应 用 程序 的 权 
限 , 例 如 选择 “执行 (包括 脚本 )” 单 选 按钮 , 则 允许 访问 者 执行 目录 中 的 应 用 程序 及 其 
脚本 。 

(5) 设置 完毕 , 单 击 “ 确 定 ” 按 钮 保存 设置 并 返回 到 共享 文件 夹 属性 对 话 框 ,再 单 击 
“确定 ”按钮 即 可 。 
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而 医 到 CEEER 


让 Internet 信息 服务 


共享 位 置 00) 到 | 
@ 不 共享 文件 夹 如 
共享 文件 亚 E) 
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目录 四) ER 
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Ot 
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口 执行 包括 脚本 ) 到 ) 


图 6-4 文件 夹 属性 对 话 框 图 6-5 “编辑 别名 ”对 话 框 


6.2 SQL Server 2000 的 配置 与 管理 


6.2.1 设置 选项 


使 用 企业 管理 器 的 图 形 工具 和 代码 都 可 以 调整 SQL Server 的 选项 ,但 是 必须 要 注意 
的 是 ,在 企业 管理 器 和 查询 分 析 器 中 都 是 无 法 设置 SQL Server 的 全 部 选项 的 。 虽然 企 业 
管理 器 具有 易于 使 用 的 优点 ,可 以 使 用 易于 理解 的 对 话 框 ,通过 点 选 的 方式 选择 各 种 选 
项 ,在 其 引导 下 一 步 一 步 地 完成 相应 的 配置 任务 。 但 是 ,与 在 查询 分 析 器 中 使 用 脚本 进行 
配置 的 方式 相 比 ,这 种 方式 缺乏 可 重复 性 。 

1. 配置 服务 器 


服务 器 级 配置 选项 控制 服务 器 范围 内 的 设置 ,如 SQL Server 如 何 使 用 硬件 . 它 如 何 
在 Windows 平台 下 执行 多 线程 任务 及 一 个 触发 器 是 否 能 够 触发 其 他 的 触发 器 等 。 在 配 
置 服务 器 时 ,必须 牢 牢记 住 配置 的 目标 在 于 : 一 致 性 和 性 能 。 

在 服务 器 的 属性 对 话 框 中 可 以 用 图 形 化 的 方式 配置 许多 服务 器 选项 。 要 启动 服务 器 
的 属性 对 话 框 ,可 以 在 控制 台 树 中 ,在 要 配置 的 服务 器 上 单 击 鼠 标 右键 ,并 从 弹出 的 快捷 
菜单 中 选择 “属性 ”命令 。 

在 企业 管理 器 中 ,通过 “SQL Server 属性 (配置 )” 对 话 框 的 “常规 ”选项 卡 可 以 了 解 服 
务 器 的 版 本 和 环境 ,如 图 6-6 所 示 。 

使 用 代码 也 可 以 获取 同样 的 信息 。 例 如 ,可 以 通过 @@Version 全 局 变量 来 获取 服 
务 器 的 版 本 信息 : 
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服务 器 设置 。 | “数据 库 设置 。 | ”复制 | 
六 | 内 存 。 | 处 理 器 | 安 作 | 连接 


Es 名 称 : 100100.100.80 

产品 : SQL Server Developer Ediion 
操作 系统 - Microsoft Windows NT — 5.1 [2600) 
产品 版 本 8.00.2039 [SP4] 

语言 中 文中 国 ) 

操作 平台 - NT INTEL X95 

换 作 系统 内 存 : 254MB) 

处 理 器 : nh 

根 目录 CNProgram Fles\Microsoft SQL 
服务 器 排序 规则 - Chinese_PRC_CI_AS 

「 在 换 作 系统 启动 时 自动 启动 策略 


友 自动 启动 SQL Server M] 
厂 自动 启动 SQL Server 代 理 山 
厂 自动 局 动 MSDTC @) 
启动 参数 P). 
网 络 配置 IN) . 
mm | wm | 


6-6 ”企业 管理 器 的 服务 器 属性 对 话 框 一 一 “常规 ”选项 卡 


Select @@Version 

对 于 许多 配置 属性 的 更 改 都 必须 要 等 到 SQL Server 重新 启动 才 会 生效 。 基 于 这 个 
原因 ,在 “SQL Server 属性 (配置 ) ”对话 框 的 “服务 器 设置 ?选项 卡 中 ,通过 选择 对 话 框 底 
部 的 单 选 按钮 ,可 以 分 别 显示 改动 后 的 配置 值 和 当前 所 采用 的 运行 时 值 。 

在 代码 中 ,可 以 使 用 sp_configure 系统 存储 过 程 来 设置 许多 的 服务 器 选项 。 如 果 在 
执行 它 时 不 指定 任何 参数 , 它 就 会 返回 服务 器 的 当前 设置 ,如 下 面 的 代码 所 示 。 

EXEC sp_configure 

使 用 扩展 的 存储 过 程 一 一 xp_msver, 可 以 返回 其 他 服务 器 和 环境 属性 的 信息 。 

EXEC xp_msver 

ServerProperty() 系 统 函 数 是 另 一 种 可 以 用 来 获取 服务 器 信息 的 方法 。 该 函数 的 优 
点 在 于 : 可 以 在 Select 语句 的 表达 式 中 使 用 它 。 例 如 .下 面 的 代码 就 使 用 了 ServerProp- 
erty() 函数 来 获取 SQL Server 实例 的 版 本 信息 。 


Select ServerProperty ('Edition') 


2. 配置 数据 库 

数据 库 级 的 选项 用 于 配置 当前 数据 库 在 ANSI 兼容 性 和 恢复 方面 的 设置 。 

在 企业 管理 器 的 数据 库 属性 对 话 框 中 可 以 设置 绝 大 多 数 的 数据 库 选项 。 要 打开 这 个 
对 话 框 , 可 以 在 控制 台 树 中 ,使 用 鼠标 右键 单 击 要 操作 的 数据 库 , 并 从 弹出 的 快捷 菜单 中 
选择 “属性 ”命令 。 该 对 话 框 的 “选项 ”选项 卡 如 图 6-7 所 示 。 

在 代码 中 ,使 用 sp_dboption 系统 存储 过 程 可 以 对 数据 库 配 置 选 项 进行 设置 。 如 果 
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党 规 | 数据 文件 | 事务 日 志 | 文件 组 选项 | 权限 | 


模型 MF 完全 可 

设置 

厂 ANSI NULL 默认 设置 E] 厂 自动 关闭 加 

厂 递 昌 击发 器 厂 自动 收效 [N] 

厅 自动 更 新 统计 信息 人 6) 反 自动 创建 统计 信息 [C) 

厅 残雪 页 检测 [EP) 厂 使 用 被 引用 的 标识 符 中 ) 
兼容 性 一 = 

部 别 L} 数据 库 莱 容 约 别 80 了 

CD | ww | 
图 6-7 使 用 企业 管理 器 数据 库 属性 对 话 框 中 的 “选项 ”选项 卡 
来 配置 绝 大 多 数 常用 的 数据 库 属性 


在 执行 它 时 不 指定 任何 参数 , 它 就 会 列 出 所 有 可 用 的 数据 库 设置 。 
EXEC sp_dboption 


3. 配置 连接 
许多 连接 级 选项 都 是 用 于 设置 ANSI 兼容 性 或 者 连接 性 能 的 。 


连接 级 选项 的 作用 域 非常 有 限 。 如 果 是 在 交互 式 会 话 中 设置 了 连接 级 的 选项 ,那么 
一 旦 再 次 设置 了 该 选项 的 值 ,或 者 会 话 结束 了 ,刚才 对 于 选项 的 设置 就 失效 了 。 如 果 是 在 
存储 过 程 中 设置 的 连接 级 选项 ,那么 只 有 在 执行 包含 它 的 存储 过 程 时 ,这 一 设置 才 是 有 


效 的 。 


连接 级 选项 通常 是 通过 Set 命令 来 设置 的 。 下 面 的 代码 对 在 当前 会 话 中 SQL Server 


处 理 空 值 的 方式 进行 了 设置 。 
Set Ansi nulls off 
设置 连接 属性 的 另 一 种 方法 是 使 用 SessionProperty() 函 数 。 


Select SessionProperty("RNSI NULLS') 


当 查询 分 析 器 建立 到 服务 器 的 连接 时 会 设置 一 些 连接 属性 。 要 查看 连接 属性 的 默认 
值 ,可 以 在 查询 分 析 器 中 选择 “工具 ”>“ 选 项 "命令 ,并 在 打开 的 “选项 ”对 话 框 中 选择 “ 连 
接 属性 ”选项 卡 。 如 果 要 对 当前 的 连接 级 选项 进行 设置 , 则 可 以 使 用 “查询 ”>“ 当 前 连接 


属性 ”命令 ,如 图 6-8 所 示 。 
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| 腑 可 器 。 | 结果 | 连接 。 连接 屋 性 


6-8 可 以 使 用 查询 分 析 器 的 “当前 连接 属性 ?对话 框 来 查看 


或 者 设置 当前 会 话 的 连接 级 属性 


6.2.2 局 动 SQL Server 数据 库 服 务 


安装 完成 SQL Server 2000 后 ,在 程序 菜单 里 找到 Microsoft SQL Server 2000 程序 


组 , 单 击 * 服 务 管 理 器 ?菜单 项 以 启动 Microsoft SQL 名 


Server 服务 管理 器 ,如 图 6-9 所 示 。 

在 “服务 器 "下 拉 列 表 中 选择 一 个 服务 器 。 如 没有 
启动 SQL Server 服务 时 ,可 以 单 击 “ 开 始 / 继 续 ” 按 钮 
以 启动 SQL Server 服务 。 

启动 之 后 .可 以 单 击 “ 暂 停 ”或 “停止 ”按钮 来 暂停 
和 中 断 服务 。“ 和 暂停 ”按钮 用 于 暂时 停止 服务 ,所 有 设 
置 不 改变 ,重新 开始 服务 时 ,速度 较 快 ;停止 "按钮 用 
于 关闭 该 服务 ,所 有 设置 被 储存 ,再 次 开始 服务 时 , 重 
新 调和 数据 及 设置 ,速度 较 慢 。 


6.2.3 使 用 SQL Server 企业 管理 器 


SQL Server 企业 管理 器 如 图 6-10 所 示 。 


刷新 服务 0 
| 天/ 作乱 加 
| 暂停 中) 
| 停 上 加 
反 当局 动 0S 时 自动 启动 服务 (4) 
正在 支行 -WWICRISOF-6300B2 -NSSQLServer 


图 6-9 SQL Server 服务 管理 器 


在 SQL Server 组 中 的 NIUJIYIN-9EAECO(Windows NT) 服 务 器 中 ,有 几 个 文件 来 


用 于 管理 SQL Server 数据 库 。 
1. 数据 库 


在 数据 库 列 表 中 列 出 了 这 个 数据 源 中 包含 的 数据 库 。 有 一 些 是 系统 自 带 的 数据 库 ， 
如 master、model、msdb、Northwind、pubs 和 tempdb; 有 一 些 是 用 户 自己 建立 的 数据 库 ， 
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文件 外， 拱 作 (4) 埋 看 人) 工具 (I) 官 口 (D 帮助 {0D 
+ + 白 国 关 李 日 民 攻 洲 全 有 凤 生 本 包 


aspnet Coursep... CREDIT 。 DEChange DBMEWP TBSecurity eon 
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i 国 
ti bt el, gn ep 
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图 6-10 SQL Server 企业 管理 器 


如 DBNEMP (如 图 6-11 所 示 ) 和 newedu。 


文件 抑 作 (8) 查 着 (加 工具 (I 鲜 口 嚼 林 助 (H) 
CE adel Wr 
ED roe 一 


ee 


spnet 
Coureopublishine 
i arpnet CourseF... CREDIT 。 DBChange DME DBSecurity edu 


四 通明 四 四 是 0 
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TDChange 


利息 昌 四 香 申 用 昌 四 和 用 是 甲 旦 和香 昌平 用 日 申 引 和 昌 日 平 中 日 
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图 6-11 DBNEMP 数据 库 


可 以 用 右键 单 击 左边 树 形 控件 里 的 NEMP2 实现 对 数据 库 的 管理 ,管理 的 内 容 包 括 
设置 数据 库 属性 、 视 图、 导入 数据 、 导 出 数据 、 备 份 数 据 库 、 还 原 数据 库 及 生成 SQL 脚本 
等 ,如 图 6-12 所 示 。 
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(1) 展开 DBNEMP 下 的 “ 表 ” 节 点 ,如 图 6-12 所 示 。 


文件 人 B 操作 他 查看 (工具 GT) 窗口 人 0 考 助 (D 
EPE 有 ZTE 


上 AAA 


一 | 
ie 
[和 g 
32a"EEB FE 
8B “地 站 轩 党 当 站 
有 
Ed 


瑟 秤 团 用 田 母 


图 6-12 DBNEMP 数据 库 中 的 表 


在 右边 信息 窗口 中 会 列 出 该 数据 库 中 所 有 的 表 , 包 括 建立 数据 库 时 SQL Server 自动 
建立 的 和 用 户 建立 的 。 

从 返回 信息 中 可 以 看 出 表 的 名 称 、 所 有 者 、 类 型 和 创建 日 期 , 单 击 相 应 按钮 可 以 按 该 
属性 排序 。 在 这 些 表 中 ,System 类 型 的 表 很 多 ,它们 是 SQL Server 用 于 维护 该 数据 库 而 
自动 创建 的 ,初学 者 不 应 该 擅自 更 改 这 些 表 ,否则 有 可 能 导致 所 建立 的 数据 库 无 法 正常 运 
行 ,从 而 导致 整个 网 站 瘫痪 。 

用 户 可 以 右键 单 击 空白 处 ,在 弹出 的 快捷 菜单 中 选择 “新建 表 ”命令 或 者 右键 单 击 树 
中 的 “ 表 ? 节 点 ,在 弹出 的 快捷 菜单 中 选择 “新 建 表 ”命令 ,这 两 种 方法 都 可 以 创建 一 个 
新 表 。 

另外 ,通过 单 击 右键 ,在 弹出 的 快捷 菜单 中 还 可 以 选择 完成 以 下 功能 。 

。 设计 表 。 

。 查询 表 。 

。 设置 访问 权限 。 

(2) 展开 DBNEMP 下 的 “用 户 ” 节 点 ,可 以 查看 和 设置 该 数据 库 的 用 户 。 

右边 信息 窗口 中 列 出 了 有 该 数据 库 访问 权限 的 用 户 , 如 图 6-13 所 示 。 可 以 右键 单 击 
空白 区 域 ,在 弹出 的 快捷 菜单 中 选择 “新 建 数 据 库 用 户 ” 命 令 增 加 该 数据 库 的 用 户 ,或 者 右 
键 单 击 某 一 个 用 户 ,在 弹出 的 快捷 菜单 中 选择 “属性 "命令 来 更 改 该 用 户 的 权限 属性 。 

(3) 展开 DBNEMP 下 的 “角色 ”节点 ,可 以 查看 和 设置 该 数据 库 中 的 角色 。 

右边 信息 窗口 中 列 出 了 该 数据 库 中 的 所 有 角色 ,如 图 6-14 所 示 。 可 以 右键 单 击 空白 
区 域 ,在 弹出 的 快捷 菜单 中 选择 “新 建 数据 库 角色 ?命令 增加 该 数据 库 的 角色 ,或 者 右键 单 
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让 


D5ecurity 


图 6-13 DBNEMP 数据 库 中 的 用 户 
击 某 一 个 角色 ,在 弹出 的 快捷 菜单 中 选择 “属性 ”命令 来 更 改 该 角色 的 权限 属性 及 包含 的 


文件 (外 损 作 (&) 查看 工具 (TD) 本 口 虽 帮助 () 
# + 提 国 关 语 日 可 国米 父 取 日 本局 
后 二 100, 80 (Wandows NT) 可 医 工 10 个 项 目 
8 EE | 
ee ab_acceasadaim 标准 
Se cb_backupcperator 计 准 
TDChange eb_datareadar 本 让 
TB bdatawrlter 天 从 
于 关于 图 dlatnin 有 省 
其 ab_derydatareader 新 稚 
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Ea 
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日 
自 
日 
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自 
自 
日 
| 
EE | 
旧 
息 
日 
图 6-14 DBNEMP 数据 库 中 的 角色 
2. 数据 转换 服务 


数据 转换 服务 (Digital Theatre System，DTS) 允许 在 Microsoft SQL Server、OLE 
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DB、ODBC 或 文本 文件 (x* . TXT) 等 结构 的 多 个 数据 源 之 间 输 入 和 输出 数据 ,以 及 在 运行 
SQL Server 2000 的 多 台 计 算 机 之 间 执 行 数据 库 和 数据 库 对 象 的 传输 。 程 序 员 还 可 以 用 
DTS 来 执行 数据 转换 ,以 便 用 它 来 通过 一 个 在 线 事务 处 理 系统 建立 数据 仓库 和 数据 商 
场 。DTS 也 可 以 通过 批 通信 程序 (Baird Capital Partners,BCP) 来 输出 和 输入 数据 。 

数据 转换 服务 设计 器 (Designer) 是 一 种 非常 简单 快捷 的 数据 导入 、 导 出 和 转换 工具 。 
DTS 设计 器 可 以 利用 面向 事务 的 工作 流 引 擎 设计 执行 复杂 工作 流 的 DTS 包 , 进 行 集成 
化 的 数据 移动 。DTS 设计 器 使 用 百分之百 的 OLE DB 体系 结构 ,能 在 众多 流行 的 客户 
机 /服务 器 数据 源 间 完成 复制 .转换 数据 等 操作 。 它 提供 了 与 Access、 Excel、 FoxPro、 
SQL Server ,dBase Paradox、Oracle.DB-2 和 AS/400 多 种 数据 源 的 连接 ,如 图 6-15 所 示 。 
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3. 管理 

在 这 里 有 着 丰富 的 管理 工具 ,包括 SQL Server 代理 ,备份 、 当 前 活动 数据库 维护 计 
划 和 SQL Server 日 志 等 .如 图 6-16 所 示 。 

其 中 ,备份 可 以 为 一 个 现存 的 数据 库 创建 一 个 备份 。 在 电子 商务 网 站 中 ,数据 的 安全 
性 很 重要 。 虽 然 数据 丢失 不 可 避免 ,但 如 果 丢 失 了 数据 ,而 没有 备份 ,整个 网 站 就 一 无 所 
有 ,不 能 继续 运行 了 。 

当前 活动 可 以 实时 监控 当前 数据 库 状 态 ,如 图 6-17 所 示 。 

4. 安全 性 

在 这 里 用 户 可 以 管理 数据 库 服务 器 的 安全 属性 ,如 图 6-18 所 示 。 

安全 性 包括 登录 、 服 务 器 角色 、 链 接 服务 器 和 远程 服务 器 几 项 ,它们 的 功能 如 下 。 
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图 6-17 当前 活动 
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图 6-18 安全 性 


(1) 登录 用 于 管理 使 用 该 SQL Server 的 登录 用 户 。 

(2) 服务 器 角色 用 于 管理 该 SQL Server 使 用 者 的 角色 。 

(3) 链接 服务 器 用 于 管理 链接 的 服务 器 。 

(4) 远程 服务 器 用 于 管理 远程 服务 器 。 

提示 : 这 里 的 SQL Server 使 用 者 角色 与 上 文 提 到 的 数据 库 的 角色 不 同 。 前 者 是 针 
对 整个 SQL Server 的 使 用 来 说 的 , 它 的 权限 设 定 关系 到 整个 数据 库 服务 器 ;而 后 者 是 针 
对 这 个 SQL Server 服务 器 中 的 一 个 数据 库 说 的 , 它 的 权限 设置 只 决定 该 用 户 对 该 数据 库 
的 权限 ,与 同一 数据 库 服 务 器 中 的 其 他 数据 库 没 有 关系 。 而 登录 用 户 即 为 数据 库 用 户 , 数 
据 库 用 户 必须 先行 登录 。 

展开 “登录 ”节点 ,在 右边 信息 窗口 中 列 出 了 该 SQL Server 服务 器 中 所 有 的 注册 用 
户 , 如 图 6-19 所 示 。 

其 中 有 一 个 内 置 用 户 , 即 BUIL TIN\Administrators, 该 用 户 是 NT Group 组 策略 认 
证 方式 。 

另外 还 有 一 个 默认 用 户 sa, 该 用 户 在 安装 SQL Server 时 被 注册 。 

其 他 的 用 户 都 是 用 户 自己 定义 的 ,除了 BUIL TIN/Administrator 这 个 用 户 。 

右键 单 击 空白 区 域 .在 弹出 的 快捷 菜单 中 选择 “新 建 登 录 ” 命 令 增 加 该 数据 库 服 务 器 
的 注册 用 户 ,或 者 右键 单 击 某 一 个 用 户 ,在 弹出 的 快捷 菜单 中 选择 Properties 命令 来 更 改 
该 用 户 的 权限 属性 。 
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图 6-19 登录 


6.2.4 SQL Server 2000 的 备份 方法 


1. SQL Server 2000 备份 数据 库 的 4 种 方法 

SQL Server 2000 备份 数据 库 的 4 种 方法 如 下 。 

(1) 数据 库 备份 , 即 制作 数据 库 中 所 有 内 容 的 副本 。 在 备份 过 程 中 , 它 需 要 花费 的 时 
间 和 空间 最 多 ,不宜 频繁 进行 。 恢 复 时 , 仅 需要 恢复 最 后 一 次 全 库 备 份 。 该 备份 以 后 的 修 
改 都 将 丢失 。 

(2) 差异 备份 , 即 只 备份 最 后 一 次 全 库 备份 后 被 修改 的 数据 页 。 备 份 所 耗 时 间 和 空 
间 较 少 。 恢 复 时 , 先 恢复 最 后 一 次 全 库 备 份 , 再 恢复 最 后 一 次 差异 备份 。 

(3) 事务 日 志 备 份 , 即 只 备份 最 后 一 次 日 志 备 份 后 所 有 的 事务 日 志 记 录 。 备 份 所 用 
的 时 间 和 空间 更 少 。 利 用 日 志 备 份 进行 恢复 时 ,可 以 指定 恢复 到 某 一 个 事务 。 例 如 ,可 以 
将 其 恢复 到 某 个 破坏 性 操作 执行 前 一 个 事务 ,这 是 全 库 备份 和 差异 备份 所 不 能 做 到 的 。 
但 利用 日 志 备份 进行 恢复 时 ,需要 重新 执行 日 志 记 录 中 的 修改 命令 来 恢复 数据 库 中 的 数 
据 ,所 以 通常 恢复 的 时 间 较 长 。 建 议 每 周 进行 一 次 全 库 备 份 ,每 天 进行 一 次 差异 备份 ,每 
小 时 执行 一 次 日 志 备份 ,这 样 最 多 只 会 丢失 一 小 时 的 数据 。 人 恢复 时 , 先 恢 复 最 后 一 次 全 库 
备份 ,再 恢复 最 后 一 次 差异 备份 ,再 依次 恢复 最 后 一 次 差异 备份 以 后 进行 的 所 有 事务 日 志 
备份 。 

(4) 文件 或 文件 组 备份 , 即 备份 某 个 数据 库 文件 或 数据 库 文件 组 。 这 种 方法 必须 与 
日 志 备 份 结合 才 有 意义 。 例 如 . 某 数据 库 中 有 两 个 数据 文件 ,一 次 仅 备 份 一 个 文件 ,而 且 
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在 每 个 数据 文件 备份 后 ,都 要 进行 日 志 备份 。 在 恢复 时 ,使 用 事务 日 志 所 使 用 的 数据 文件 


恢复 到 同一 个 时 间 点 。 


备份 数据 库 可 以 使 用 备份 向 导 或 企业 管理 器 来 完成 ,也 可 以 通过 Transact-SQL 语 


句 来 实现 。 
2. 使 用 备份 向 导 备 份 数据 库 示 例 


下 面 以 继 教 网 数据 库 DBNEMP 为 例 , 介 绍 使 用 备份 向 导 备 份 数据 库 的 方法 和 步骤 。 


(1) 在 企业 管理 器 中 展开 服务 器 组 ,然后 展 


开 一 个 服务 器 。 

(2) 展开 “数据库 ”文件 夹 ,然后 单 击 要 备份 
的 数据 库 , 如 DBNEMP。 

(3) 选择 “工具 ”一 “向 导 ” 命 令 , 然 后 打开 如 
图 6-20 所 示 的 “选择 向 导 ” 对 话 框 。 

(4) 单 击 “ 管 理 ” 节 点 ,选择 “备份 向 导 ” 选 项 ， 
确定 后 弹出 “创建 数据 库 备份 向 导 ” 对 话 框 ,然后 
单 击 “ 下 一 步 ” 按 钮 ,出 现 如 图 6-21 所 示 的 对 
话 框 。 

(5) 选择 所 备份 的 数据 库 ( 如 DBNEMP) , 单 
击 “ 下 一 步 ” 按 钮 ,出 现 “ 输 入 备份 的 名 称 和 描述 ” 
对 话 框 ,在 该 对 话 框 中 输入 备份 的 名 称 和 描述 信 
息 ,然后 单 击 * 下 一 步 ? 按 钮 ,出 现 如 图 6-22 所 示 
的 对 话 框 。 

(6) 选择 下 列 备份 方法 之 一 。 


索引 优化 向 导 
复制 


生成 目标 服务 器 向 导 
数据 库 维护 计划 向 导 


Cue |] wn | 


图 6-20 “选择 向 导 ” 对 话 框 


< 上 - 步 四 取消 


图 6-21 选择 要 备份 的 数据 库 


中“ 数据 库 备份 ”: 对 整个 数据 库 进 行 备份 。 


@ “差异 数据 库 ”: 对 新 的 或 更 改 的 数据 库 进 行 备份 。 
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个 差异 数据 库 - 芭 备份 新 的 和 已 更 改 的 数据 [D) 


个 事务 日 志 -备份 对 数据 库 的 所 有 更 改 的 记录 [G) 


— mw | 
6-22 选择 备份 类 型 


@ “事务 日 志 ”: 对 数据 库 的 所 有 更 改 的 记录 进行 备份 。 
选择 一 种 备份 方法 之 后 ,鼠标 左 键 单 击 “ 下 一 步 "按钮 ,出 现 如 图 6-23 所 示 的 对 话 框 。 


“te. ®@ 


三 选择 备份 设备 
个 三 带 下 二 

区 FE Progam Fles\Microson SaL Seve ME =| 
个 备份 设备 区 } ” 

属性 
人 追加 到 备份 媒体 加 ] 

个 重 写 备份 媒体 0) 

厂 备份 后 弹出 碍 硕 E) 

厂 备份 后 读 职 并 验证 备份 的 完整 性 A)} 


《上 - 步 四 | 下- 步 中 ) 取消 
图 6-23 选择 备份 目的 和 操作 


(7) 选择 备份 目的 和 操作 。“ 选 择 备份 设备 "选项 为 "文件 ”方式 ,其 中 文件 名 和 路 径 
自 定义 。 如 果 要 将 此 次 备份 追加 到 原 有 备份 数据 的 后 面 ,可 以 选择 “属性 ?选项 区 域 中 的 
“追加 到 备份 媒体 ” 单 选 按钮 ;如 果 要 用 此 次 备份 的 数据 覆盖 原 有 备份 数据 ,可 以 选择 “ 重 
写 备 份 媒体 ” 单 选 按钮 。 单 击 “ 下 一 步 "按钮 .出现 如 图 6-24 所 示 的 对 话 框 。 

(8) 单 击 “ 更 改 ” 按 钮 ,确定 备份 的 计划 .然后 单 击 " 下 一 步 ” 按 钮 ,出 现 备 份 向 导 的 “ 完 
成 ”对话 框 ,如 图 6-25 所 示 。 在 该 对 话 框 中 显示 刚才 所 设置 的 各 属性 , 单 击 “ 完 成 ”按钮 ， 
如 图 6-26 所 示 。 则 出 现 备 份 进度 的 对 话 框 ,结束 后 弹出 完成 对 话 框 ,如 图 6-27 所 示 。 这 
样 ,用 向 导 完成 了 数据 库 的 备份 ,并 在 相应 的 文件 夹 内 产生 了 一 个 . bak 备份 文件 。 
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图 6-24 备份 验证 和 调度 


正在 完成 创建 数据 库 备份 向 导 


人 该 备份 的 定义 


据 库 
Disk: [C:\Program Files\Microsoft SQL Serve 
追加 备份 并 

名称、 是 


» 


mm 
图 6-25 ”完成 对 话 框 


正在 进行 备份 

将 数据 库 : DBNEMP 备份 到 设备 : :IC\Progam 
Fies\Microsoft SQL 
Servei\MSSQL\BACKUP\DBNEMP 备份 .BAK] 
LTTTTTTTTTTITIITTIT 


ED 
图 6-26 “备份 进度 ”对 话 框 图 6-27 ”完成 对 话 框 
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6.2.5 临时 、 永 久 备 份 文件 的 建立 


1. 永久 备份 文件 的 建立 

执行 备份 的 第 一 步 是 创建 要 包含 备份 内 容 的 备份 文件 。 在 备份 执行 之 前 所 创建 的 备 
份 文件 称 为 永久 性 的 备份 文件 ,这些 永久 性 的 备份 文件 也 称 为 备份 设备 。 如 果 和 希望 重新 
使 用 已 创建 的 备份 文件 ,或 者 设置 系统 自动 备份 数据 库 , 就 必须 使 用 永久 性 的 备份 文件 。 
创建 永久 性 备份 文件 有 两 种 方法 : 使 用 SQL Server Enterprise Manager, 或 者 执行 系统 
存储 过 程 sp_addumpdevice。 

执行 系统 存储 过 程 sp_addumpdevice, 可 以 在 磁盘 或 磁带 上 创建 永久 性 的 备份 文件 ， 
或 者 将 数据 定向 到 某 个 命名 管道 (Named Pipe) 中 。 创 建 永久 性 的 备份 文件 时 ,应 该 考虑 
下 列 因 素 。 

(1) SQL Server 系统 在 master 数据 库 中 的 系统 表 sysdevices 中 ,创建 该 永久 性 备份 
文件 的 逻辑 名 称 和 物理 名 称 。 

(2) 必须 指定 该 备份 文件 的 逻辑 名 称 和 物理 名 称 。 

(3) 一 个 数据 库 最 多 可 以 创建 32 个 备份 文件 。 

使 用 SQL Server Enterprise Manager 创建 一 个 新 的 永久 性 备份 文件 ,实际 上 就 是 
SQL Server 系统 执行 系统 存储 过 程 sp_addumpdevice。 系 统 存 储 过 程 sp_addumpdevice 
的 语法 形式 如 下 : 

[EXECUTE] sp_addumpdevice ' 设 备 类 型 ', ' 逻 辑 名 称 ', ' 物 理 名 称 ' [, {{controller_type| 

'device status'}}] 


其 中 ,设备 类 型 是 {DISK|TAPE|PIPE) , 即 磁盘 、 磁 带 或 命名 管道 。 


USE master 
EXEC sp_addumpdevice 'disk', 'archivebackupfile', 'C:\Program Files\Microsoft SQL Server\ 
MSSQL\BACKUP\arbackupfile.bak"' 


2. 临时 备份 文件 的 建立 

如 果 不 打 算 重 新 使 用 某 些 备份 文件 ,就 可 以 创建 临时 的 备份 文件 。 创 建 临时 备份 文 
件 有 两 种 方法 : 使 用 SQL Server Enterprise Manager, 或 者 使 用 BACKUP DATABASE 
语句 。SQL Server 系统 可 创建 临时 文件 ,以 存储 备份 操作 的 结果 。 在 创建 临时 文件 时 ， 
必须 指定 介质 类 型 (磁盘 、 人 磁带 或 命名 管道 ) 和 完整 的 路 径 名 称 、 文 件 名 称 。BACKUP 
DATABASE 语句 的 语法 形式 如 下 。 


BACKUP DATABASE {database name|@ database name var} 
TO<backup file> [,**,n] 


其 中 ,二 backup_file 二 是 


{ backup file namel@ | backup file name evar}|{DISK|TAPE|PIPE}= 
{temp file namel@ temp_ name evar} 
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在 磁盘 上 创建 了 一 个 临时 备份 文件 ,并 且 把 DBNEMP 数据 库 备 份 到 该 临时 备份 文 
件 上 。 
创建 一 个 临时 备份 文件 ,程序 清单 如 下 。 


USE master 
BACKUP DATABASE archive TO DISK= 'C:\Temp\ TempRrchive.bak' 


使 用 BACKUP 语句 可 以 对 数据 库 进 行 全 库 备 份 、 差 异 备份 、 日 志 备份 或 文件 和 文件 
组 备份 。 

1) 全 库 备份 

全 库 备份 即 制作 数据 库 中 所 有 内 容 的 一 个 副本 。 从 一 个 全 库 备份 中 就 可 以 恢复 整个 
数据 库 。 其 语法 形式 为 : 

BACKUP DATABASE ”数据库 名 TO 备份 设备 名 

[WITH [NAME= "备份 的 名 称 '] [,INITINOINIT]] 


在 上 述 语法 格式 中 ,备份 设备 名 采用 “备份 设备 类 型 = 设备 名 称 ” 的 形式 ;INIT 参数 
表示 新 备份 的 数据 覆盖 当前 备份 上 的 每 一 项 内 容 , 即 原来 在 此 设备 上 的 数据 都 将 不 存在 
了 ;NOINIT 参数 表示 新 备份 的 数据 添加 到 备份 设备 上 已 有 内 容 的 后 面 。 

例如 ,对 数据 库 DBNEMP 做 一 次 全 库 备 份 , 并 保存 在 永久 备份 文件 一 一 本 地 磁盘 设 
备 archivebackupfile 中 ,而 且 此 次 备份 覆盖 以 前 所 有 的 备份 。 代 码 如 下 : 


BACKUP DATABASE archive TO DISK= 'archivebackupfile' 
WITH INIT, NAME= 'archivebackup'" 


2) 差异 备份 

差异 备份 即 从 最 近 一 次 全 库 备 份 结束 以 来 ,所 有 改变 的 数据 的 备份 。 当 数据 库 从 上 
次 备份 以 来 ,数据 发 生 很 少 的 变化 时 ,适合 使 用 差异 备份 。 其 语法 格式 如 下 : 

BACKUP DATABASE 数据库 名 To 备份 设备 名 

WITH DIFFERENTIRAL [，NRME= ' 备 份 的 名 称 '] [,INITINOINIT]] 


其 中 ,DIFFERENTIAL 子 句 的 作用 是 ,指定 只 对 在 创建 最 新 的 数据 库 备 份 后 ,数据 
库 中 发 生变 化 的 部 分 进行 备份 。 

对 数据 库 DBNEMP 进行 差异 备份 ,并 保存 在 永久 备份 文件 一 一 本 地 磁盘 设备 ar- 
chivebackupfile 中 ,代码 如 下 : 


BACKUP DATABASE archive TO DISK= 'archivebackupfile' 

WITH DIFFERENTIAL, NAME= 'archivebackup', NOINIT 

3) 日 志 备 份 

日 志 备 份 即 从 最 后 一 次 日 志 备 份 以 来 所 有 事务 日 志 备 份 到 备份 设备 。 通 常 ,日 志 备 
份 经 常 与 全 库 备份 和 差异 备份 结合 使 用 ,其 语法 格式 如 下 : 


BACKUP LOG 数据 库 名 To 备份 设备 名 
[WITH [NAME- ' 备 份 的 名 称 '] [,INITINOINIT]] 
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对 数据 库 DBNEMP 进行 日 志 备 份 ,并 保存 在 永久 备份 文件 一 一 本 地 磁盘 设备 ar- 
chivebackupfile 中 ,代码 如 下 : 

BACKUP LOG archive TO DISK= 'archivebackupfile" 

WITH NAME= 'archivebackup', NOINIT 

4) 文件 和 文件 组 备份 

当 一 个 数据 库 很 大 时 ,对 整个 数据 库 进行 备份 可 能 花费 很 多 时 间 , 这 时 可 以 采用 文件 
和 文件 组 备份 方式 , 即 对 数据 库 中 的 部 分 文件 或 文件 组 进行 备份 。 其 语法 格式 如 下 : 

BACKUP ”DATABASE 数据 库 名 

FILE= "文件 的 逻辑 名 称 '1FILEGROUP= "文件 组 的 逻辑 名 称 ' To 备份 设备 名 

[WITH NAME= "备份 的 名 称 '] [,INITINOINIT] 

使 用 上 述 语 法 格式 备份 数据 库 时 ,如 果 备 份 是 文件 , 则 写 做 “FILE==' 文 件 的 逻辑 名 
称 ” 的 方式 ;如 果 备 份 是 文件 组 , 则 写 做 *FILEGROUP= 文 件 组 的 逻辑 名 称 ” 的 方式 。 

将 DBNEMP 数据 库 的 archive_data 文件 备份 到 本 地 磁盘 设备 filebackup。 代 码 
如 下 : 


BACKUP DATABASE archive FILE= "archive data' to DISK= 'filebackup’ 


6.2.6” 继 教 网 数据 库 系 统 的 设计 


前 面 用 了 大 量 篇 幅 对 SQL Server 2000 数据 库 的 使 用 进行 了 介绍 ,希望 对 读者 后 面 
的 学 习 有 所 帮助 。 

1. 建立 数据 库 DBNEMP 

下 面 介绍 如 何 为 继 教 网 建立 一 个 数据 库 DBNEMP。 建 立 该 数据 库 的 步骤 如 下 。 

(1) 打开 SQL Server 企业 管理 器 。 

(2) 选择 Microsoft SQL Server 习 SQL Server 组 一 100. 100. 100. 80(Windows NT) 
一 数据 库 。 

(3) 右键 单 击 * 数 据 库 ”节点 ,在 弹出 的 快捷 菜单 中 选择 “新 建 数据 库 命 令 ,将 弹出 一 
个 “数据 库 属性 ”对 话 框 ,如 图 6-28 所 示 。 

(4) 在 “常规 ”选项 卡 中 ,可 以 在 “名 称 ” 文 本 框 中 指定 数据 库 名 字 , 如 DBNEMP。 

(5) 在 “数据 文件 ”选项 卡 中 ,可 以 设置 数据 库 文件 的 名 字 和 存放 位 置 。 默 认 文件 名 
是 DBNEMP ,默认 位 置 是 C:\Program Files\Microsoft SQL Server\MSSQL\Data\ DB- 
NEMP. mdf, 即 在 SQL Server 安装 目录 的 \Data 子 目录 中 ,如 图 6-29 所 示 。 

“初始 大 小 ”项 用 来 设 定数 据 库 文件 初始 大 小 ,默认 值 是 1MB。 这 个 值 可 根据 自己 的 
网 站 规模 大 小 来 决定 。 

(6) 在 如 图 6-30 所 示 “ 事 务 日 志 ” 选 项 卡 中 ,可 以 进行 如 下 设置 。 

a 在 “事务 日 志文 件 ” 选 项 区 域 中 ,可 以 设置 事务 日 志文 件 的 文件 名 位 置 和 初始 
大 小 。 

@ 在 “文件 属性 ”选项 区 域 中 ,选中 “文件 自动 增长 ” 复 选 框 ,可 以 让 SQL Server 服务 
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党 规 。 数据 文件 | 事务 日 志 | 


文件 属性 
文件 自动 增长 [6] 
= 


个 按 光 字 节目 夺 
人 按 百 分 比 BF "0 | 


6-28 “数据 库 属性 ”对 话 框 


田园 Messenger 
由 国 Microsoft ActiveSync 
外国 microsoh hontpage 
由 鲜 Micosoh Office 

日 外 Micosoh SQL Server 


由 向 L0G 
由 图 REPLDATA 
由 鲜 Upgade ~ 


文件 名 EE} [DeNEMP_Daa MDF I 


园 定 的 文件 : CNProgam Fies\Mictosoft SOL Serve\MSSQL\Dala\[ 
— ww | 


图 6-29 DBNEMP_Data. MDF 的 默认 位 置 


器 自动 增加 事务 日 志文 件 的 大 小 。 

加 “文件 增 长 ?选项 区 域 用 于 选择 文件 自动 增长 的 方式 .或 者 按 兆 字 节 增长 ,或 者 按 
百分比 增长 。 

@“ 最 大 文件 大 小 ”选项 区 域 用 于 决定 事务 日 志文 件 的 最 大 尺寸 。 默 认 是 不 限定 文 
件 大 小 。 

这 样 就 建立 了 一 个 名 为 DBNEMP 的 数据 库 , 它 的 各 项 参数 如 下 。 

。 数据 库 文件 为 DBNEMP, 保 存在 C:\Program Files\ Microsoft SQL Server\ 
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第 规 | 数据 文件 事务 日 志 | 


事务 日 志文 件 人 ET] 
件 名 位 置 初始 大 小 MB) 


Ealeswel sewedl 


图 6-30 “事务 日 志 ” 选 项 卡 


MSSQL\Data 中 。 

事务 日 志文 件 为 DBNEMP_Log. ldf, 保 存在 C:\Program Files\Microsoft SQL 
Server\MSSQL\Data 中 。 

。 文件 初始 大 小 是 1MB。 

每 次 到 达 规 定 尺寸 ,就 自动 增加 10% 的 大 小 。 

没有 最 大 尺寸 限制 。 

2. 创建 访问 DBNEMP 数据 库 的 新 登录 

下 面 将 为 DBNEMP 数据 库 建立 一 个 新 登录 。 建 立 登录 的 步骤 如 下 。 

在 企业 管理 器 左边 的 树 形 控件 中 选择 “安全 性 ”节点 。 

(1) 在 右边 窗口 中 出 现 的 “登录 "图标 上 单 击 右键 。 

(2) 在 弹出 的 快捷 菜单 中 ,选择 “新 建 登录 ”命令 来 建立 一 个 新 登录 ,如 图 6-31 所 示 。 

选择 “新 建 登 录 ” 命 令 后 ,将 出 现 如 图 6-32 所 示 的 对 话 框 , 它 有 “常规 ”" “服务器 角 
色 ” 和 “数据 库 访问 ”三 个 选项 卡 。 

1)“ 常 规 ” 选 项 卡 

在 “常规 ”选项 卡 的 “名 称 ” 文 本 框 中 输入 新 登录 的 名 称 , 如 图 6-32 所 示 。 

“身份 验证 ?选项 区 域 用 于 指定 登录 的 认证 方式 。 有 两 种 方式 ,其 一 为 Windows 身份 
验证 ,表示 采用 Windows 用 户 认证 。 当 采用 这 种 方式 认证 时 ,只 有 使 用 该 Windows 用 户 
登录 系统 的 用 户 才 被 SQL Server 作为 合法 用 户 。 其 二 为 SQL Server 身份 验证 ,表示 使 
用 SQL Server 用 户 认 证 .SQL Server 为 该 登录 建立 一 个 账号 ,要求 输 入 密码 。 

这 里 采用 SQL Server 身份 验证 ,密码 设 为 DBNEMP。 

在 “默认 设置 ”选项 区 域 中 ,可 以 设 定 默 认 数 据 库 和 默认 语言 。 这 里 设置 默认 数据 库 
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文件 四 “操作 他 |， 这 看 (WD 工具 (T] 窗口 但 帮助 ( 
+ 后 国 XxX 地 贱民 久米 个 即 自 功 色 
”去 和 性 。 4 个 天 上 


证 时 昌 母 再 旨 上 峡 评 时 本 苹 苹 - 竺 塌 日 侠 蛙 昌 可 四 乎 时 日 弗 乎 早日 晤 曲 | 


瑟 围 母国 
也 外 四 官 
| 
上 


6-31 新 建 登录 


er 登录 属性 新 建 登录 


CSOLServer 身 


se 


默认 设置 
指定 此 登录 的 默认 语言 和 数据 库 . 


图 6-32 “常规 ”选项 卡 


为 刚才 建立 的 DBNEMP 数据 库 , 默 认 语言 为 “默认 ”。 
2)“ 服 务 器 角色 ”选项 卡 
“服务 器 角色 ?选项 卡 如 图 6-33 所 示 。 
在 这 个 选项 卡 中 可 以 设置 登录 在 服务 器 范围 内 的 安全 特性 , 它 的 设置 决定 了 该 登录 
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SQL Server 登录 属性 一 新 建 登录 
常规 。 服务 器 角色 | 数据库 访 问 | 
服务 器 角色 一 一 
苹 服务 器 角色 用 于 对 登录 授予 服务 器 范围 内 的 安全 特权 区 )。 


口 Database Creators 
描述 吕 ) 


和 


图 6-33 “服务 器 角色 ”选项 卡 


可 以 执行 哪些 操作 ,如 System Administrators、Security Administrators、Server Adminis- 
trators 及 Setup Administrators 等 。 


单 击 * 属 性 ?按钮 ,出现 “服务 器 角色 属性 ?对 话 框 ,在 其 中 可 以 查看 所 选 定 角色 的 属 
性 ,如 图 6-34 所 示 。 


服务 器 角色 属性 
第 规 | 权限 | 


C4 名 称 IN System Administrators 


sysadain 


指定 嘲 些 登录 犀 于 此 安全 性 角色 的 成 员 [GT 


B 


PNET 
BUILTINVAdministrators 
elect 


BE 


添加 A} MSE) 
wl eel 
6-34 “服务 器 角色 属性 ”对话 框 


在 该 对 话 框 的 “常规 ”选项 卡 中 列 出 了 属于 该 角色 的 登录 。 使 用 者 可 以 在 该 角色 中 增 
加 、 删 除 这 些 登录 。 在 “权限 ”选项 卡 中 , 列 出 了 指定 服务 器 角色 所 能 执行 的 操作 。 

图 6-35 所 示 为 Disk Administrators 可 执行 的 操作 。 

3)“ 数 据 库 访 问 ” 选 项 卡 

“数据 库 访问 ?选项 卡 如 图 6-36 所 示 。 

在 “指定 此 登录 可 以 访问 的 数据 库 ? 列 表 框 中 , 列 出 了 该 SQL Server 数据 库 服务 器 中 
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服务 器 角色 属性 一 sysadain 
常规 权限 | 
此 服务 器 角色 可 执行 下 列 命令 - 


数据 库 角 色 中 区 许 


图 6-36 “数据 库 访问 ”选项 卡 


所 有 的 数据 库 , 有 DBNEMP、pubs 及 Northwind 等 。 

将 允许 此 登录 访问 的 数据 库 名 字 前 的 “许可 ” 复 选 框 选中 ,否则 这 个 登录 就 无 法 访问 
该 数据 库 。 这 里 选择 DBNEMP 数据 库 。 

在 “DBNEMP 的 数据 库 角色 ?列表 框 中 可 设 定 此 登录 的 访问 权限 ,可 以 是 public、db_ 
owner 或 db_accessadmin 等 。 


将 public 与 db_owner 选中 ,使 该 用 户 有 完全 的 权限 访问 控制 数据 库 。 
6.2.7 设计 Role 表 


在 SQL Server 企业 管理 器 中 选中 DBNEMP 数据 库 下 的 “ 表 ” 节 点 ,如 图 6-37 所 示 。 
这 里 所 列 出 的 表 包 括 SQL Server 自动 生成 的 表 ( 用 于 维护 数据 库 , 初 学 者 不 应 随意 
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六 件 是 ) 捧 作 (&] 普 看 (加 工具 (I) 亩 口 (WD ”帮助 (也 
“+ 证 国 X 全 X 四 名 久米 从 5 自 轩 名 
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2007-9-24 9 
2007-9-21 9 


seindonkors 
加 srenonbers 


国 央 从 

月 户 定义 的 数据 基 型 
月 户 定义 的 函 迷 
全 文 目录 


国 sysrererences 
nonp2tonp 
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图 6-37 “ 表 ” 节 点 


改变 ) 和 自 定义 的 表 。 

现在 就 开始 建立 一 个 表 。 在 右边 窗 格 的 任意 位 置 单 击 右键 或 右键 单 击 * 表 ”节点 ,在 
弹出 的 快捷 菜单 中 选择 “新 建 表 ”命令 ,建立 一 个 新 数据 表 , 如 图 6-38 所 示 。 

SQL Server 提示 输入 一 个 表 名 ,该 名 字 不 能 与 数据 库 中 已 有 的 表 名 重复 。 

先 建立 一 个 角色 表 , 名 字 为 Role, 如 图 6-39 所 示 。 也 可 以 给 它 一 个 完全 不 同 的 名 字 ， 
不 过 一 般 要 符合 见 名 知 意 原则 。 


所 有 任务 人) 
查看 Q) 
从 这 里 自 建 窗口 四) 


刷新 到 ) 
导出 列表 C) 


帮助 0 


图 6-38 ”快捷 菜单 图 6-39 输入 表 名 


输入 表 名 后 ,SQL Server 就 建立 了 一 个 名 为 Role 的 表 。 

然后 对 表 进 行 设计 ,如 图 6-40 所 示 。 设 定 各 个 列 的 列 名 ,数据 类 型 .数据 长 度 (所 占 
字 节 数 )、 精 度 ( 数 值 型 数据 的 位 数 )、 小 数位 数 .是否 允许 为 空 , 默 认 值 .标识 .标识 种 子 、 标 
识 递 增 量 及 是 否 为 RowGrid。 

将 第 一 列 命 名 为 Roleld ,标识 设 为 “是 ”, 标 识 种 子 设 为 1, 标 识 递增 量 也 设 为 1。 这 
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database dafault》 


6-40 ”对 Role 表 进 行 设计 


样 ,数据库 中 每 增加 一 条 记录 ,RoleId 字段 就 会 自动 加 1。 


Roleld 的 数据 类 型 一 般 可 设 为 int 型 ,长 度 为 4 个 字 节 ,也 就 是 可 以 容纳 
4 228 250 625 个 用 户 ,这 几乎 对 于 任何 规模 的 网 站 都 是 足够 的 。Tiny-int 型 数据 长 为 一 
个 字 节 ,只 能 容纳 256 个 用 户 , 这 显然 不 够 。 

右键 单 击 空白 处 ,在 弹出 的 快捷 菜单 中 选择 “属性 "命令 ,弹出 表 的 “属性 ”对 话 框 ,如 


图 6-41 所 示 。 


在 此 “属性 ”对话 框 中 ,可 以 更 改 表 名 ,如 将 Role 改 成 任何 其 他 名 字 ; 可 以 改变 表 文 件 


组 和 文本 文件 组 ,默认 的 值 为 PRIMARY ;还 可 以 建立 ,管理 对 表 和 列 的 检查 约束 。 


再 打开 “索引 / 键 " 选 项 卡 ,如 图 6-42 所 示 。 


| 关系 “| 索引 / 键 | cck 约束 | 


6-41 表 的 “属性 ”对 话 框 


于 。 | 关系 。 委 引 / 键 | cc 约束 | 


mas: [mv | 
选 定 的 索引 (E) [Ix_Role 
mi。 车- as | 
索引 名 四 ): [ele 


Relerd 了 J 升序 白 
素 引 文件 组 人 @: [PRINARY 了 
[到 填充 因子 人 E): 
约束 四 [国王 
人 个案 引 Q) 。_ 厂 和 号 委 各 当 0) 厂 填充 款 引 


厂 他 尘 为 CLUSTERED CC) 
厂 不 自动 重新 计算 蚁 计 芭 ) 


记 舌 ] 一 


图 6-42 “索引 / 键 ”选项 卡 
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在 “ 选 定 的 索引 ”下 拉 列 表 中 选择 PK_Role 项 ,可 以 看 到 “类 型 " 栏 里 的 “主键 " 变 成 了 
“索引 ”。 单 击 “ 新 建 "按钮 ,从 “ 列 名 ”下 拉 列 表 中 选择 RoleId 作为 索引 。 这 样 ,查询 数据 
库 时 ,速度 会 因 建 立 了 索引 而 加 快 。 

这 样 Role 表 就 设计 好 了 。Role 表 的 各 个 字段 含义 比较 简单 ,读者 可 以 理解 。 

按照 上 述 方法 ,再 分 别 建立 其 他 的 表 。 


6.3 发 布 站 点 


6.3.1 发 布 Web 页 


要 想 在 Web 站 点 上 发 布 信息 ,首先 应 建立 Web 站 点 ,同时 指明 哪些 目录 包含 要 发 布 
的 文档 。Web 服务 器 无 法 发 布 未 在 这 些 指 定 目录 中 的 文档 。 所 以 ,配置 Web 站 点 的 第 
一 步 是 确定 文件 的 组 织 方式 。 可 以 使 用 Internet 信息 服务 管理 器 确定 哪些 目录 是 站 点 的 
一 部 分 。 当 安装 Windows Server 2000 时 ,IIS 将 创建 默认 的 Web 站 点 。 如 果 和 希望 马上 
开始 而 不 创建 特殊 的 目录 结构 ,并且 文件 全 部 位 于 运行 Internet 信息 服务 的 计算 机 上 , 那 
便 可 以 立刻 将 Web 文件 复制 到 默认 的 主 目录 C:\InetPub\wwwroot 来 发 布 文档 (对 于 
FTP 站 点 ,应 将 文件 复制 到 C:\InetPub\Ftproot)。 内 部 网 用 户 可 以 输入 “http:// 服 务 器 
名 /文件 名 ”访问 到 这 些 文件 。 

1. 在 默认 Web 站 点 上 发 布 内 容 

(1) 为 Web 站 点 创建 主页 。 

(2) 将 主页 文件 命名 为 Default. aspx。 

(3) 将 主页 复制 到 IIS 的 默认 Web 发 布 目录 中 。 默 认 Web 发 布 目录 也 称 为 主 目录 ， 
安装 程序 提供 的 位 置 是 \InetPub\wwwroot。 

(4) 如 果 网 络 具有 名 称 解析 系统 (通常 为 DNS) ,那么 访问 者 可 以 简单 地 在 其 浏览 器 
地 址 栏 中 输入 Web 站 点 名 来 访问 站 点 。 如 果 网 络 没有 名 称 解析 系统 ,那么 访问 者 必须 输 
入 Web 站 点 的 数字 IP 地 址 。 

2. 定义 主 目录 

每 个 Web 站 点 必须 有 一 个 主 目录 。 主 目录 位 于 所 发 布 网 页 的 核心 位 置 。 它 包含 带 
有 欢迎 内 容 的 主页 或 索引 文件 ,并 且 包含 到 所 在 站 点 其 他 网 页 的 链接 。 主 目录 映射 为 站 
点 的 域名 或 服务 器 名 。 例 如 .如 果 站 点 的 Internet 域名 是 www. microsoft. com, 并 且 主 
目录 是 C:\Website\Microsoft ,那么 浏览 器 将 使 用 URL http://www. microsoft. com 访 
问 主 目录 中 的 文件 。 在 内 部 网 上 ,如 果 服 务 器 名 是 MADIS-lhf ,浏览 器 将 使 用 URL ht- 
tp://MADIS-LHF 访问 主 目录 上 的 文件 。 


6.3.2 发 布 站 点 


如 果 一 切 就 绪 并 编译 成 功 ,使 用 Visual Web Developer 发 布 Web 站 点 。 具 体 步 又 如 下 。 
(1) 在 Microsoft Visual Studio2005 中 打开 本 项 目 NEMPOffice(D:\ NEMPOffice) ,选择 
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菜单 “网 站 ”一 “复制 网 站 ”( 如 图 6-43 所 示 )。 


源 网 站 (人 D : x|lB 远程 网 站 (了) : 国 || 六 || 晤 


名称 间 态 售 改 日 期 。 种 3 _ 修 下 日 其 
回 上 


[ul 

4 

生 : : 
sls [ts 


DFileNne 
BHoneWork 
Honevork. .. 
BHoneWork. .. 


各 onlineco … 
国 PecsorHo.… a 


6-43 复制 网 站 页 面 


(2) 单 击 连接 : 连接 到 框 , 并 在 文本 框 中 输入 NEMPOffice, 如 图 6-44 所 示 。 


和 Messenger 
由 国 Microsoft ActiveSync 
困 仿 ) mictosoft hontpage 
由 国 Microsok Office 

日 向 Microsoh SQL Server 


外国 REPLDATA 


”由 鲜 Upgade 
文件 名 EE [DBNEMP_DataMDF 三 
选 定 的 文件 : C:\Program Files\Microsoft SQL Server\MSSQL\Data\[ 


Ce ]_ ws | 
6-44 “查找 数据 库 文件 ”对 话 框 


要 想 在 远 端 实际 部 署 站 点 ,要 选择 左 端 菜 单 中 的 远程 站 点 ,然后 提供 站 点 位 置 的 
URL 或 IP 地 址 ,可 能 还 要 输入 相关 用 户 ID 和 密码 。 不 幸 的 是 .对 于 已 经 部 署 站 点 的 读 
者 不 能 测试 站 点 的 Web 空间 。 

(3) 单 击 “ 打 开 ” 按 钮 ,并 在 弹出 窗口 提问 是 否 要 创建 一 个 新 文件 夹 时 单 击 Yes 按钮 。 

(4) 选择 所 有 文件 ,如 图 6-45 所 示 。 


(5) 单 放 


上 f 蓝 色 向 右 箭头 按钮 复制 文件 ,如 图 6-46 所 示 。 
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源 网 站 (DD) : 国 ||xj|| 色 远程 网 站 (加 : 义 || 曾 
http://localhost/NEIPOffice D: WWENPOff ice 
名 称 装 态 修改 日 期 | | 名称 | 状态 | 修改 日 期 
Business. 
usiness. 
BDatatcce. 
BLenelop. 
可 | | Greworrice 
YebRefer... 
| | = 国 x=:cepo 2007-10-28 11:0d 
如 加 Emorri 2007-9-28 15:20 
| | “EPorri, 2007-4-9 9:57 
3 各 国 vssver.scc 新 建 2007-10-28 13:09 
1 » 
图 6-45 建立 远程 连接 
“复制 站 https. 本 本 0EEice| -x 
http://1lecalhoot/NENPOfEico TAIEIEOEEIES ~ 
| 修改 上 期 ~ Em [类 | 修改 日 期 


[a 


cowreestudy 
eas 
BExcel 
FileNane 
BHoneVork 
Honevork. .. 


ss|[*][] 


上 1 
上 次 岗 新 : 2007-12-30 11:27 上 次 刷新 : 2007-12-30 11:27 
星 东 自 上 次 复制 操作 后 删除 的 文件 人 D》 


图 6-46 复制 


(6) 选择 “文件 ”>“ 关 闭 " 命 令 , 关 闭 站 点 。 
(7) 选择 “文件 ”>“ 打 开 ”>“ 网 站 ”命令 ,然后 选择 NEMPOffice。 
(8) 运行 新 的 Web 站 点 ,如 图 6-47 所 示 。 
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WE: 5093 


厂 义 上 来 党 ， 远程 教 育 是 扫 交 课件 革 送 约 外 的 一 外 或 多 间 字 员 的 教育 。 全 照 六 个 定义 ， 运往 孝 
育 的 历 可 以 壬 吕 到 19 世 纪 30 午 世 开 始 的 商业 古 柑 课程 。 但 是 活 音 先 渤 入 信 息 技术 ,特别 所 htmet 的 
出 现 ， 运 和 我 让 叶 证 友 生 了 评 鸡 专 炒 。 的 确 ,技术 的 志 于 大 丰 新 向 远 和 教育 的 传 搞定 义 提 出 了 
鞭 战 ， 结 是 ， 名 和 项 目 ， 苇 二 吉 苍 学员 和 媒 诗 才 大 圣 使 用 “运程 教育 ” 这 一 本店 。 
运程 教育 是 基于 计 类 . 议 类 (二 姑 取 录 们 ) 有 包括 实 对 和 寺 实 时 至 大 的 计算 机 技术 把 过 虽 
程 传送 3 了 外 校园 外 的 教 再 ， 这 一 远程 教育 的 定义 不 包括 专门 在 术 园 内 及 只 通过 书面 记 丈 进 生 的 


误 程 《 尽管 远程 教育 中 也 包括 一 些 在 要 的 指导 或 考试 ， 其 中 一 些 指导 其 看 全 芭 
“ 远程 禾 育 的 桂 点 管理 贡 ! 。 2007.01-06 


秆 理 RI 30170105 


攻 理 而 | 。 2001.01-04 


张 2008-01.07 


2001-01.06 
20080L07 
2008-0110 


2008.0110 


天 于 我 站 可 共 阁 站 项目 合作 不 各 声明 招 了 作息 。 FL 寺 图 入 本 各 协 。 Eaeiah 


产权 所 有 。 保 贸 所 有 如 利 。 


6-47 更 新 后 的 Web 
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在 计算 机 系统 中 ,网 站 是 最 容易 受到 攻击 的 对 象 ,因为 网 站 本 来 就 是 暴露 在 Internet 
中 让 用 户 访问 的 ,所 以 受到 攻击 不 可 避免 ,关键 是 如 何 提高 自身 的 抗 攻击 能 力 。 在 面临 网 
络 电子 商务 的 全 面 开 展 之 际 ,网 站 的 安全 问题 将 成 为 建设 大 型 电子 商务 系统 的 一 个 非常 
关键 的 问题 。 本 章 从 网 站 所 面临 的 安全 问题 和 人手 ,介绍 一 些 提高 网 站 安全 性 能 的 措施 和 
手段 。 


7.1 网 站 安全 


网 站 的 安全 包括 网 站 的 系统 安全 和 网 站 的 信息 安全 。 如 果 是 租用 的 虚拟 主机 或 申请 
的 网 页 空间 ,那么 安全 的 主要 工作 由 提供 商 承担 ,但 还 是 有 许多 问题 需要 考虑 。 如 果 是 拥 
有 自己 的 服务 器 ,那么 就 必须 全 面 地 考虑 网 站 安全 的 问题 。 
网 站 安全 的 内 容 包括 网 站 实体 的 安全 ,如 计算 机 机 房 的 物理 条 件 和 设施 .计算 机 硬件 
和 网 络 设施 及 附属 设备 等 ;网 站 软件 的 安全 ,保证 网 站 不 受 计算 机 病毒 的 侵害 、 不 被 非法 
侵入 、 网 站 软件 不 被 非法 复制 算 改 等 ;网 站 中 数据 的 安全 ,对 于 网 站 中 重要 的 数据 不 被 非 
法 存 取 ,保证 数据 的 完整 性 等 ;网 站 的 安全 管理 ,如 建立 安全 的 管理 制度 、 对 突 发 事件 的 应 
急 措 施 等 。 

要 做 好 网 站 的 安全 应 该 从 影响 网 站 的 安全 因素 入 手 。 首 先是 网 站 系统 软件 的 选择 ， 
以 保证 其 自身 的 安全 。 对 网 站 中 比较 重要 的 数据 ,分 级 别 存放 ,针对 不 同 的 用 户 开放 不 同 
的 共享 级 别 。 对 于 较 大 网 站 的 安全 管理 ,可 设置 一 定 的 安全 管理 规范 ,配置 安全 管理 员 
等 。 还 有 一 个 影响 网 站 安全 的 因素 就 是 病毒 和 黑客 的 入 侵 , 这 可 能 是 对 网 站 危害 最 大 的 
一 个 因素 ,防止 此 类 危害 的 一 个 有 效 手段 就 是 使 用 防火 墙 技术 。 

所 谓 防火 墙 其 实 是 位 于 服务 器 上 的 一 种 程序 , 它 是 网 络 上 的 一 种 隔离 控制 技术 ,可 在 
某 网 站 和 外 界 不 安全 网 站 之 间 设 置 障碍 。 它 具有 双向 的 功能 , 既 可 阻止 外 界 对 信息 资源 
的 非法 访问 ,也 可 以 防止 站 内 信息 的 非法 输出 。 


7.1.1 网 站 所 面临 的 安全 问题 


要 提高 网 站 的 安全 性 能 ,必须 了 解 网 站 面临 的 安全 问题 ,需要 对 网 络 信 息 系统 存在 的 
安全 缺陷 和 可 能 受到 的 各 种 攻击 有 深入 和 正确 的 理解 , 正 所 谓 知 己 知 彼 , 才 能 百 战 不 列 。 
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当 评判 一 个 网 站 是 否 面临 安全 问题 时 ,要 从 多 方面 了 解 各 个 组 件 的 弱点 是 什么 ,包括 硬件 
和 软件 平台 ,因为 安全 性 的 高 低 取 决 于 最 薄弱 环节 .符合 “水 桶 理论 ”, 即 弱 的 部 分 决定 了 
整体 安全 性 能 ,而 且 黑 客 攻击 也 是 从 薄弱 的 环节 入 手 。 通 过 近 几 年 在 Internet 上 发 生 的 
黑客 攻击 事件 可 以 看 出 ,威胁 网 络 安全 的 基本 模式 都 很 相似 ,特别 是 在 大 量 黑 客 软件 工具 
出 现 以 后 ,使 得 网 站 的 安全 受到 更 严重 的 威胁 。 

隐藏 在 世界 各 地 的 攻击 者 通常 可 以 利用 网 站 所 有 可 能 的 错误 ,包括 设计 错误 、 安 装配 
置 错 误 等 ,向 网 络 发 起 攻击 。 系 统 软件 存在 的 漏洞 是 最 大 隐患 ,因为 攻击 者 只 要 找到 某 一 
种 系统 软件 的 安全 漏洞 .那么 他 就 可 以 攻击 所 有 使 用 这 种 系统 软件 的 网 站 ,所 以 及 时 地 为 
系统 软件 做 安全 补丁 是 很 重要 的 。 

除了 自然 灾害 外 ,通常 将 网 络 的 安全 漏洞 分 为 两 大 类 。 

1. 软 硬 件 系 统 平台 的 安全 漏洞 

其 包括 无 意 的 漏洞 和 有 意 的 漏洞 。 无 意 的 漏洞 是 系统 设计 过 程 中 不 经 意 的 失误 或 欠 
深入 考虑 而 造成 的 ,例如 主机 存放 的 环境 问题 ,物理 防范 措施 不 当 等 ;有 意 的 漏洞 是 某 些 
系统 设计 人 员 专 门 开 的 后 门 ,虽然 开始 不 为 人 知 , 可 是 时 间 长 了 一 旦 泄露 出 去 ,后 果 就 不 
堪 设 想 。 硬 件 方面 如 PIII 芯片 的 序列 号 问题 ,软件 方面 如 微软 的 设计 人 员 曾 在 ASP 页 
面 中 开 了 查看 源 文件 的 后 门 ,这 个 漏洞 需要 安装 一 些 SP 补丁 包 才能 解决 。 

2. 自身 的 人 为 安全 隐患 

不 管 是 有 意 还 是 无 意 的 ,人 为 因素 往往 对 网 站 安全 有 重要 影响 。 例 如 操作 员 安 全 配 
置 不 当 造 成 的 安全 漏洞 ;用 户 安全 意识 不 强 , 口 令 选 择 不 慎 , 将 自己 的 账号 随意 转借 他 人 
或 与 别人 共享 等 都 会 对 网 络 安全 带 来 威胁 。 

1) 系统 平台 的 安全 

首先 Internet 这 个 大 网 络 平台 从 建立 开始 就 缺乏 总 体 的 安全 构想 和 设计 ,而 且 
TCP/IP 协议 是 在 可 信 的 环境 下 专门 对 网 络 互联 设计 的 ,缺乏 全 面 安全 措施 的 考虑 ,所 以 
Internet 的 网 络 安全 就 成 为 互联 技术 发 展 的 一 个 关键 因素 。 在 这 样 的 大 环境 下 ,就 要 加 
强 自身 系统 的 防范 。 建 立 网 站 必须 要 有 硬件 和 软件 平台 ,其 中 可 能 包括 主机 、 防 火 墙 、 路 
由 器 \ 防 病毒 墙 、 操 作 系 统 、Web 服务 器 、 电 子 邮 件 服务 器 和 数据 库 等 ,其 中 任何 一 个 方面 
的 安全 缺陷 都 有 可 能 对 网 站 的 安全 造成 潜在 的 危险 。 

对 于 系统 平台 的 安全 ,一 般 需 要 考虑 以 下 问题 。 

(1) 确认 服务 器 、 操 作 系统 和 其 他 系统 软件 是 否 有 安全 漏洞 ,如 果 有 ,是 否 有 相应 的 
措施 预防 。 对 于 硬件 ,确认 是 否 要 更 换 部 件 , 软 件 是 否 要 安装 补丁 程序 等 。 

(2) 采用 适当 的 措施 保护 Web 服务 器 主机 系统 不 会 受到 外 网 或 内 网 的 攻击 。 

(3) 保护 Web 服务 器 免 于 拒绝 服务 的 攻击 。 

(4) 采用 一 次 性 登录 方式 ,减少 账户 管理 的 复杂 度 ,简洁 的 账户 系统 更 容易 实施 安全 
策略 ,对 过 期 不 用 的 账户 应 及 时 删除 。 

(5) 建立 一 个 可 持续 周转 的 安全 策略 ,并 确保 策略 的 实施 。 

(6) 注意 网 站 安全 日 志 的 记录 与 查看 ,因为 绝对 安全 的 系统 是 不 存在 的 ,安全 的 网 站 
和 不 安全 的 网 站 也 是 相对 而 言 , 所 以 安全 的 网 站 抗 攻击 能 力 较 强 , 攻 击 者 可 能 会 花费 很 大 
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的 精力 和 时 间 才 能 攻破 。 在 这 段 时 间 里 ,如 果 能 随时 查阅 安全 日 志 , 发 现 有 攻击 存在 时 ， 
采取 必要 的 措施 就 可 以 使 攻击 者 退却 。 

一 个 安全 的 系统 至 少 要 做 到 当 某 一 部 分 被 攻破 时 ,其 影响 范围 应 该 尽量 最 小 化 ,避免 
安全 问题 进一步 扩散 ,例如 即使 泄露 一 个 文件 的 密 钥 ,攻击 者 也 不 能 解 开 硬盘 上 所 有 的 加 
密 文 件 。 作 为 一 个 优秀 的 系统 设计 者 ,必须 考虑 人 侵 发 生 后 的 应 对 办 法 ,并 且 在 设计 时 还 
应 该 设想 一 下 如 果 系 统 被 攻破 应 该 怎么 办 。 

攻击 者 攻破 了 某 个 网 络 目录 服务 器 ,由 此 将 对 某 些 服务 器 的 访问 定向 到 攻击 者 指定 
的 机 器 ,该 机 器 可 能 中 断 客 户 和 服务 器 之 间 来 往 的 数据 ,使 客户 和 服务 器 双方 都 没有 意识 
到 第 三 方 的 存在 ,很 多 敏感 数据 就 此 被 窃取 。 这 种 方式 通常 被 称 为 "中间人 ”攻击 。 

在 内 部 网 中 , 当 各 工作 站 使 用 共享 文件 系统 共享 可 执行 文件 时 ,一 个 内 部 攻击 者 可 能 
监听 了 工作 站 向 文件 服务 器 发 出 的 文件 访问 请 求 ,抢先 把 修改 过 的 文件 块 传 给 工作 站 。 
由 于 内 部 网 缺少 判断 数据 包 发 送 地 址 的 能 力 , 工 作 站 会 接收 该 数据 包 , 将 真正 的 包 当 做 重 
复数 据 丢 弃 , 从 而 工作 站 将 毫 无 察觉 地 使 用 修改 后 的 程序 。 这 类 错误 应 该 算 一 个 比较 严 
重 的 问题 ,当前 许多 操作 系统 在 这 方面 没有 做 很 大 的 改进 。Windows NT 的 Service 
Pack 3 虽然 注意 到 了 这 个 问题 ,但 在 同 其 他 系统 的 互 操作 性 方面 却 受 到 了 影响 。 

2) 自身 的 人 为 因素 

许多 系统 被 攻破 是 因为 它们 严重 依赖 于 用 户 创 建 的 口令 ,为 了 便于 记忆 ,用 户 通 常 选 
择 简单 容易 的 字符 串 而 不 选择 复杂 性 很 强 的 口令 ,即使 该 口令 被 加 密 , 比 起 随机 生成 的 密 
码 也 更 容易 破解 。 此 外 ,为 了 工作 上 的 方便 ,有 些 用 户 可 能 会 把 自己 的 口令 告知 同事 ,从 
而 有 可 能 散布 开 。 通 常 负责 密 钥 管理 和 系统 维护 的 人 越 多 ,系统 出 问题 的 可 能 性 就 越 大 。 
对 此 ,最 好 的 解决 办 法 是 建立 完整 的 安全 策略 ,严格 控制 用 户 的 权限 及 对 关键 信息 的 访 
问 。 对 于 银行 之 类 的 系统 ,必要 时 可 对 某 些 关键 数据 采用 秘密 共享 机 制 的 保护 策略 ,以 保 
证 在 若干 个 人 同时 在 场 的 情况 下 才能 启用 。 与 此 同时 ,还 要 加 强 审计 功能 ,保证 每 一 件 事 
务 都 有 据 可 查 。 安 全 系统 应 该 能 够 提供 解决 这 一 问题 的 机 制 , 不 允许 任何 人 在 系统 中 留 
有 后 门 。 对 于 安全 因素 需要 考虑 以 下 问题 : 确保 被 保护 的 Web 内 容 只 有 少数 人 员 被 授 
予 特定 的 访问 权限 ;更 换 系统 维护 人 员 时 需要 更 改 关 键 的 口令 。 

3) 攻击 方式 

对 网 站 的 攻击 一 般 都 是 人 为 的 恶意 攻击 ,这 是 计算 机 网 络 所 面临 的 最 大 威胁 ,敌手 的 
攻击 和 计算 机 犯罪 就 属于 这 一 类 。 此 类 攻击 又 可 以 分 为 以 下 两 种 : 一 种 是 主动 攻击 , 它 
以 各 种 方式 有 选择 地 破坏 信息 的 有 效 性 和 完整 性 ; 另 一 类 是 被 动 攻击 , 它 是 在 不 影响 网 络 
正常 工作 的 情况 下 ,进行 截获 .窃取 和 破译 重要 机 密 信息 。 这 两 种 攻击 均 可 对 计算 机 网 络 
造成 极 大 的 危害 ,并 导致 机 密 数据 的 泄露 。 

常见 的 攻击 方法 分 为 以 下 几 种 类 型 : 试探 ,扫描 、 窃 取 用 户 账号 获得 超级 用 户 权限 、 
数据 包 窃 听 、 拒 绝 服 务 、 利 用 信任 关系 、 恶 意 代 码 ( 如 特洛伊 木马 .病毒 和 “蠕虫 "等 ) 及 攻击 
Internet 基础 设施 (如 DNS 系统 和 网 络 路 由 等 ) 。 

一 般 来 说 ,攻击 者 对 目标 进行 攻击 要 经 历 三 个 步骤 : 情报 搜集 、 系 统 的 安全 漏洞 检查 
和 实施 攻击 。 情 报 搜集 的 目的 是 为 了 得 到 所 要 攻击 的 目标 系统 的 相关 信息 ,为 进一步 行 
动 做 好 准备 。 攻 击 者 可 以 利用 公开 的 协议 或 工具 ,也 可 以 利用 一 切 可 以 获得 的 情报 ,收集 
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目标 网 络 系统 中 的 各 个 主机 系统 的 相关 信息 。 这 些 公开 协议 及 工具 包括 HTTP、FTP、 
SMTP 及 Telnet 等 ,网 络 服务 可 能 会 暴露 操作 系统 类 型 和 版 本 等 信息 。SNMP 协议 、 
Traceroute 等 工具 可 以 用 来 检查 网 络 系统 路 由 表 、 到 达 目 标 主机 所 要 经 过 的 网 络 和 有 关 
路 由 信息 细节 。WHOIS 协议 .DNS 服务 器 及 NetBIOS 协议 等 可 能 会 给 出 目标 主机 名 称 
等 信息 。 不 同 TCP/IP 协议 的 实现 会 产生 不 同 的 “指纹 ”, 可 用 于 判断 目标 主机 所 使 用 的 
操作 系统 。 一 般 来 说 ,在 使 用 自动 化 工具 时 ,这 两 步 可 以 同时 进行 。 当 攻击 者 使 用 上 述 方 
法 ,收集 或 探测 到 一 些 有 用 信息 之 后 ,就 可 以 对 目标 系统 实施 攻击 。 

攻击 者 一 旦 获得 了 对 攻击 目标 系统 的 访问 权 后 ,又 可 能 有 多 种 选择 。 可 以 进一步 发 
现 被 攻击 系统 在 网 络 中 的 信任 关系 ,这 样 攻击 者 就 可 以 通过 信任 关系 展开 对 整个 系统 的 
攻击 ;也 可 以 在 目标 系统 中 安装 探测 器 软件 ,包括 特洛伊 木马 等 ,用 来 宕 探 所 在 系统 的 活 
动 , 搜 集 攻击 者 感 兴趣 的 信息 ,如 Telnet\FTP 及 POP3 的 账号 和 口令 等 。 如 果 攻击 者 在 
被 攻破 系统 上 获得 了 特权 用 户 权限 ,就 可 以 读 取 邮 件 、 搜 索 和 盗窃 私人 文件 .毁坏 重要 数 
据 及 破坏 整个 系统 的 信息 等 ,造成 极其 严重 的 后 果 。 此 外 ,还 可 以 清除 日 志 , 毁 掉 和 人 侵 痕 
迹 。 在 被 攻破 的 系统 上 建立 后 门 ,以 便 在 先前 的 攻击 被 发 现 后 ,还 可 以 继续 访问 这 个 

网 络 攻击 与 反攻 击 的 双方 其 实 是 极其 不 平等 的 。 对 攻击 者 来 说 ,只 要 发 现 一 点 漏洞 
就 可 以 实施 不 法 手段 ;而 对 反攻 击 者 来 说 ,需要 考虑 到 系统 的 方方面面 。 系 统 的 安全 应 该 
是 “系统 的 ”安全 ,是 全 方位 的 安全 ,需要 安全 产品 生产 者 和 用 户 双 方 做 出 很 大 的 努力 才能 
达到 。 


7.1.2 网 站 安全 的 含义 


网 站 安全 是 指 利用 网 站 管理 的 控制 和 技术 措施 ,保证 在 一 个 网 站 环境 里 ,信息 数据 的 
机 密 性 、 完 整 性 及 可 使 用 性 受到 保护 。 

网 站 安全 的 主要 目标 是 要 确保 经 网 站 传送 的 信息 ,在 到 达 目 的 站 时 没有 任何 增加 、 改 
变 、 丢 失 或 被 非法 读 取 。 要 做 到 这 一 点 ,就 必须 保证 网 站 系统 软件 、 应 用 软件 系统 和 数据 
库 系统 具有 一 定 的 安全 保护 功能 ,并 保证 网 站 部 件 如 终端 路 由 器 和 防火 墙 等 的 功能 不 
变 , 而 且 仅仅 是 那些 被 授权 的 人 可 以 访问 。 


7.1.3 网 站 安全 的 内 容 


网 站 的 安全 性 问题 实际 上 包括 两 方面 的 内 容 , 一 是 网 站 的 系统 安全 ,二 是 网 站 的 信息 
安全 ,而 保护 网 站 的 信息 安全 是 最 终 目 的 。 就 网 站 信息 安全 而 言 . 首 先是 信息 的 保密 性 ， 
其 次 是 信息 的 完整 性 。 另 一 个 与 网 站 安全 紧密 相关 的 概念 是 拒绝 服务 。 

网 站 拒绝 服务 的 表现 是 什么 ? 

拒绝 服务 是 与 网 站 系统 可 靠 性 有 关 的 一 个 重要 问题 ,主要 包括 3 个 方面 的 内 容 : 系 统 
临时 降低 性 能 ,系统 崩溃 而 需 人 工 重新 启动 ,因数 据 永久 性 丢失 而 导致 较 大 范围 的 系统 
崩溃 。 

网 站 安全 的 内 容 大 致 包括 以 下 4 个 方面 。 
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1. 网 站 实体 安全 

如 计算 机 机 房 的 物理 条 件 、 物 理 环境 及 设施 的 安全 标准 ,计算 机 硬件 .附属 设备 及 网 
站 传输 线路 的 安装 和 配置 等 。 

2. 软件 安全 

如 保护 网 站 系统 不 被 非法 侵入 ,系统 软件 与 应 用 软件 不 被 非法 复制 、 自 改 及 不 受 病毒 
的 侵害 等 。 

3. 网 站 中 的 数据 安全 

如 保护 网 站 信息 的 数据 不 被 非法 存 取 ,保护 其 完整 和 一 致 等 。 

4. 网 站 安全 管理 

如 对 运行 时 突 发 事件 的 安全 处 理 等 ,包括 采取 网 络 安全 技术 、 建 立 安全 管理 制度 、 开 
展 安全 审计 及 进行 风险 分 析 等 。 


7.1.4 网 站 的 安全 性 能 


网 站 的 安全 性 能 主要 包括 保密 性 、 完 整 性 和 可 使 用 性 三 个 方面 。 

1. 保密 性 

指 网 站 中 有 保密 要 求 的 信息 只 能 够 经 过 允许 的 人 员 以 经 过 允许 的 方式 使 用 。 从 技术 
上 说 ,任何 传输 线路 ,包括 电线 光缆、 微波 和 卫星 等 都 有 可 能 被 窃听 。 

可 以 窃听 双 绞 线 或 同 轴 电 缆 中 传输 的 信号 吗 ? 微波 也 能 被 窃听 吗 ? 

对 于 双 绞 线 或 电缆 的 窃听 ,可 以 是 接触 式 的 ;也 可 以 是 非 接触 式 的 , 即 通过 电磁 感应 或 
利用 电磁 辐射 来 窃听 。 另 外 ,现在 已 有 灵敏 度 很 高 的 TEMPEST 设备 ,即使 像 微波 那样 的 视 
距 传播 ,由 于 其 波束 有 一 定 的 宽度 ,因此 天 线 也 可 以 放 在 射线 中 央 以 外 的 地 区 接收 。 


2. 完整 性 

指 网 站 中 的 信息 安全 、 精 确 和 有 效 .不 因 种 种 不 安全 因素 而 改变 信息 原 有 的 内 容 、 形 
式 和 流向 。 造 成 信息 完整 性 被 破坏 的 原因 可 分 为 人 为 和 非 人 为 两 种 。 非 人 为 因素 如 通信 
传输 中 的 噪声 干扰 ,系统 硬件 或 软件 的 差错 等 。 人 为 因素 包括 有 意 和 无 意 两 种 ,前 者 如 非 
法 分 子 对 计算 机 的 侵入 、 合 法 用 户 越权 对 网 站 内 数据 的 处 理 ,以 及 隐藏 的 破坏 性 程序 等 ; 
后 者 如 操作 失误 或 使 用 不 当 等 。 对 于 大 多 数 网 站 来 说 ,计算 机 病毒 .时 间 炸 弹 和 逮 辑 陷阱 
等 都 属于 隐藏 的 破坏 性 程序 ,能 破坏 数据 信息 。 对 信息 完整 性 的 破坏 是 对 网 站 安全 的 主 
要 危害 。 

3. 可 使 用 性 

指 网 站 资源 在 需要 时 即 可 使 用 ,不 因 系统 故障 或 误 操作 等 使 资源 丢失 或 妨碍 对 资源 
的 使 用 。 网 站 可 使 用 性 还 包括 具有 在 某 些 不 正常 条 件 下 继续 运行 的 能 力 。 对 网 站 可 使 用 
性 的 影响 包括 合法 的 用 户 不 能 正常 访问 网 站 的 资源 ,和 有 严格 时 间 要 求 的 服务 不 能 得 到 
及 时 响应 等 。 影 响 网 站 可 使 用 性 的 因素 包括 人 为 与 非 人 为 两 种 。 前 者 如 非法 占用 网 站 资 
源 .切断 或 阻塞 网 站 通信 ,以 及 病毒 或 "蠕虫 ”降低 网 站 性 能 .甚至 使 网 站 瘫痪 等 。 后 者 如 
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7.1.5 网 站 安全 因素 


网 站 的 安全 因素 是 多 方面 的 。 从 网 站 组 成 结构 上 分 为 计算 机 信息 系统 的 ,有 通信 设 
备 和 设施 的 ;从 内 容 上 分 有 技术 上 的 ,有 管理 上 的 ;从 管理 上 分 有 内 部 的 和 外 部 的 等 。 具 
体 来 说 主要 有 以 下 几 个 方面 的 问题 。 

1. 网 站 系统 软件 自身 的 安全 问题 

网 站 系统 软件 的 自身 安全 与 否 直接 关系 到 网 站 的 安全 。 网 站 系统 软件 的 安全 功能 较 
少 或 不 全 ,以 及 系统 设计 时 的 疏忽 或 考虑 不 周 而 留 下 的 “破绽 .都 等 于 给 危害 网 站 安全 的 
人 和 事 留 下 了 许多 “后 门 ”。 

2. 网 站 系统 中 数据 的 安全 问题 

网 站 中 的 信息 数据 是 存放 在 数据 库 中 的 ,通常 也 指 存 放 在 服务 器 中 的 信息 集合 , 供 不 
同 的 用 户 来 共享 。 数 据 库存 在 着 不 安全 性 和 危险 性 ,因为 在 数据 库 系统 中 存放 着 大 量 重 
要 的 信息 资源 ,在 用 户 共享 资源 时 可 能 会 出 现 以 下 现象 , 即 授权 用 户 超出 了 他 们 的 访问 权 
限 进行 更 改 活动 ,非法 用 户 绕 过 安全 内 核 窃取 信息 资源 等 。 因 此 提出 了 数据 库 安全 问题 ， 
也 就 是 要 保证 数据 的 安全 可 靠 和 正确 有 效 。 对 数据 的 保护 主要 是 指针 对 数据 的 安全 性 、 
完整 性 和 并 发 控制 三 方面 进行 保护 。 

数据 的 完整 性 是 指 防 止 数据 库存 在 不 符合 语义 的 数据 ,以 及 防止 由 于 错误 信息 的 输 
入 、 输 出 而 造成 无 效 操作 和 错误 结果 。 并 发 控制 即 数据 库 是 一 个 共享 资源 ,在 多 个 用 户 程 
序 并 行 地 存 取 数据 库 时 ,就 可 能 会 产生 多 个 用 户 程序 通过 网 站 并 发 地 存 取 同一 数据 的 情 
况 , 若 不 进行 并 发 控制 就 会 使 取出 和 存 入 的 数据 不 正确 ,破坏 数据 库 的 一 致 性 。 


3. 传输 线路 的 安全 与 质量 问题 

尽管 在 同 轴 电 缆 、 微 波 或 卫星 通信 中 要 窃听 其 中 指定 一 路 的 信息 是 很 困难 的 ,但 是 从 
安全 的 角度 来 说 ,没有 绝对 安全 的 通信 线路 。 

4. 网 站 安全 管理 问题 

网 站 安全 管理 最 重要 的 是 从 体系 结构 上 要 实行 最 小 权限 原则 。 世 界 上 现 有 的 信息 系 
统 绝 大 多 数 缺 少 安全 管理 员 , 缺 少 信息 系统 安全 管理 的 技术 规范 ,缺少 定期 的 安全 测试 与 
检查 ,更 缺少 安全 监控 。 我 国 许多 企业 的 信息 系统 已 经 使 用 了 许多 年 ,但 计算 机 的 系统 管 
理 员 与 用 户 的 注册 大 多 还 是 处 于 默认 状态 。 

另 一 方面 ,也 可 以 说 网 站 的 安全 问题 是 天 生 的 ,这 是 由 于 “整体 大 于 部 分 之 和 ”的 原 
因 。 网 站 由 各 种 服务 器 .工作 站 和 终端 等 集群 组 成 ,所 以 整个 网 站 天 然 地 继承 了 它们 各 自 
的 安全 隐患 。 各 种 服务 器 各 自 运行 着 不 同 的 操作 系统 .各 自 继承 着 自身 系统 的 不 同安 全 
特性 。 随 着 计算 机 及 通信 设备 组 件数 目的 日 益 增 大 ,积累 起 来 的 安全 问题 会 越 来 越 多 。 


7.1.6 ”攻击 过 程 与 类 型 分 析 
典型 的 攻击 步骤 如 下 。 
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1. 宕 视 

相当 于 通常 的 穷 贼 在 远 处 张望 一 家 民居 一 样 ,黑客 首先 利用 一 些 网 络 工具 来 确定 这 些 系 
统 在 Internet 上 的 位 置 和 结构 ,发现 目标 系统 的 外 围 安 全 设备 类 型 和 结构 ,并 确定 侵入 点 。 

2. 外 围 侦察 

相当 于 现实 当中 的 窃贼 打开 门 锁 。 已 经 确定 目标 和 侵入 点 的 网 络 入侵 者 ,通过 外 转 
安全 设备 的 薄弱 环节 进入 网 络 的 正常 服务 ,如 通过 电子 邮件 系统 和 主页 系统 进入 网 络 。 

3. 寻找 内 部 落脚 点 

一 旦 侵入 者 获得 了 进入 网 络 的 权利 ,那么 下 一 步 便 是 在 外 围 设 备 中 为 自己 寻找 一 个 
安全 的 、 不 易 被 发 现 的 落脚 点 。 通 常 ,侵入 者 会 找到 一 个 能 够 获得 用 户 权限 的 主机 作为 落 
脚 点 。 落 脚 点 确定 后 ,外 部 人 侵 者 就 变 成 了 系统 内 部 人 员 ,这 时 和 人 侵 者 会 在 系统 内 部 寻找 
可 盗窃 的 财产 和 可 破坏 的 目标 系统 。 

主要 的 破坏 动作 包括 偷窃 软件 源 代码 和 财政 金融 数据 ,访问 机 密 文件 ,破坏 数据 或 硬 
件 ,还 包括 安置 为 日 后 再 次 侵入 做 准备 的 “特洛伊 木马 ”。 

破坏 动作 完成 后 ,侵入 者 必须 掩盖 自己 的 踪迹 ,以 防 被 发 现 。 典 型 的 做 法 是 删除 或 替 
换 系 统 的 日 志文 件 。 

侵入 者 对 目标 系统 的 伤害 主要 有 以 下 几 个 方面 。 

1. 非法 使 用 资源 

包括 对 计算 机 资源 、 网 络 连 接 服 务 或 电话 服务 等 资源 的 滥用 和 盗用 。 通 过 对 系统 的 
控制 ,侵入 者 能 够 无 限制 地 使 用 这 些 资源 而 不 必 付出 任何 费用 。 最 典型 的 是 免费 使 用 电 
话 系 统 或 在 全 球 的 数据 通信 和 网络 中 无 节制 地 漫游 。 这 种 攻击 很 少 造成 结构 性 的 损害 ,但 
其 高 昂 的 费用 会 转嫁 到 用 户 或 服务 商 的 头 上 。 

2. 恶意 破坏 

这 种 行为 会 对 系统 或 数据 文件 造成 破坏 ,也 可 能 会 造成 停止 对 合法 用 户 提供 服务 。 
典型 的 恶意 破坏 包括 毁坏 数据 、 修 改 页 面 内 容 或 链接 。 这 种 破坏 有 时 无 需 侵 入 网 络 ,传送 
进入 网 络 中 的 文件 可 附带 有 破坏 性 的 病毒 ,对 网 络 设备 的 信息 禾 炸 也 可 造成 服务 中 断 。 
网 络 服务 商 最 容易 受到 此 类 攻击 。 

3. 盗窃 数据 

随 着 电子 商务 的 广泛 开展 ,盗窃 行为 的 可 能 性 和 危险 性 也 在 不 断 增加 ,任何 有 价值 的 
内 容 都 有 可 能 被 盗 , 从 数据 ,服务 到 整个 数据 库 系 统 、 金 融 数 据 和 敏感 的 个 人 信息 等 。 据 
FBI 的 估计 ,每 年 由 于 此 类 数据 被 盗 而 造成 的 损失 高 达 75 亿美 元 。 

4. 敲诈 勒索 

由 于 对 破坏 系统 、 盗 窃 数 据 或 破坏 网 络 完整 性 的 怒 惧 ,企业 因此 每 年 都 要 受到 上 百 美 
元 的 勒索 。 典 型 的 勒索 方法 是 在 目标 网 络 中 安置 特洛伊 木马 程序 ,如 被 勒索 者 不 付款 , 破 
坏 程序 便 会 被 启动 。 

既然 已 经 知道 了 攻击 者 的 行为 特点 和 攻击 类 型 ,那么 一 个 有 效 的 网 络 安全 方案 就 必 
须 针 对 网 络 的 易 受 攻击 点 而 制定 保护 措施 ,同时 还 要 加 强 对 网 络 的 维护 。 一 个 系统 仅 靠 
外 围 安 全 设备 的 保护 是 不 够 的 。 典 型 的 安全 设备 ,如 传统 的 防火 墙 、 认 证 设备 及 系统 外 过 
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无 法 有 效 阻挡 侵入 者 ,它们 只 能 保护 网 络 的 入 口 ,一 旦 被 侵入 者 攻破 便 无 法 检测 到 来 自 系 
统 内 部 的 破坏 和 攻击 行为 。 

管理 者 应 尽量 缩短 对 破坏 的 反应 时 间 , 一 旦 给 攻击 者 充足 的 时 间 ,那么 任何 系统 都 有 
可 能 被 攻破 。 为 了 减少 由 于 入 侵 而 造成 的 损失 ,安全 系统 应 该 进行 实时 的 入 侵 检 测 ,对 攻 
击 行为 进行 扫描 和 拦截 。 这 种 方案 可 以 在 被 侵入 的 最 初 几 秒 钟 之 内 探测 到 危险 动作 。 安 
全 系统 应 对 侵入 做 出 快速 反应 ,能够 自动 阻挡 人 侵 者 的 破坏 行为 。 解 决 的 办 法 是 为 网 站 
安装 人 侵 检测 系统 。 

另外 ,防止 内 部 人 员 的 攻击 也 很 重要 。 据 估计 ,有 80% 的 攻击 来 自 于 内 部 人 员 。 任 
何 安装 系统 都 需要 安装 .维护 和 更 新 。 为 了 降低 开支 ,理想 的 安全 系统 应 具备 灵活 性 、 可 
扩充 性 和 透明 性 。 


7.1.7 网 站 安全 策略 


1. 物理 安全 策略 

目的 是 保护 计算 机 系统 、 网 络 服务 器 及 打印 机 等 硬件 和 通信 和 链 路 免 受 自然 灾害 、 人 为 
破坏 和 搭 线 攻击 等 。 采 用 的 措施 有 验证 用 户 的 身份 和 使 用 权限 、 防 止 用 户 越权 操作 ;确保 
计算 机 系统 有 一 个 良好 的 电磁 兼容 工作 环境 ;建立 完备 的 安全 管理 制度 ,防止 非法 进入 计 
算 机 控制 室 和 各 种 偷窃 .破坏 活动 的 发 生 。 

2. 访问 控制 策略 

访问 控制 是 网 络 安全 防范 和 保护 的 主要 策略 ,主要 任务 是 保证 网 络 资源 不 被 非法 使 用 
和 访问 。 它 也 是 维护 网 络 系统 安全 、 保 护 网 络 资源 的 主要 手段 。 各 种 安全 策略 必须 相互 配 
合 才能 真正 起 到 保护 作用 ,但 访问 控制 可 以 说 是 保证 网 络 安全 最 重要 的 核心 策略 之 一 。 

访问 控制 策略 主要 包括 以 下 几 个 方面 。 

1) 入 网 访问 控制 

入 网 访问 控制 为 网 络 访问 提供 第 一 层 访问 控制 ,控制 哪些 用 户 能 够 登录 到 服务 器 并 
获取 网 络 资源 ,控制 准许 用 户 和 人 网 的 时 间 和 准许 他 们 在 哪 台 工作 站 入 网 。 

用 户 的 入 网 访问 控制 可 分 为 三 个 步骤 : 用 户 名 的 识别 与 验证 ,用 户口 令 的 识别 与 验 
证 .用户 账 号 的 默认 限制 检查 。 三 道 关卡 中 只 要 任何 一 关 未 过 ,该 用 户 便 不 能 进入 该 网 
络 。 对 网 络 用 户 的 用 户 名 和 口令 进行 验证 是 防止 非法 访问 的 第 一 道 防线 。 用 户 登 录 时 首 
先 输入 用 户 名 和 口令 ,服务 器 将 验证 所 输入 的 用 户 名 是 否 合法 。 如 果 验 证 合法 , 才 继 续 验 
证 用 户 输入 的 口令 ,否则 用 户 将 被 拒 之 于 网 络 之 外 。 用 户 的 口令 是 用 户 人 网 的 关键 所 在 。 
为 保证 口令 的 安全 性 ,用 户口 令 不 能 显示 在 显示 屏 上 ,口令 长 度 应 不 少 于 6 个 字符 ,字符 
最 好 是 数字 、 字 母 和 其 他 字符 的 混合 。 用 户口 令 必 须 经 过 加 密 , 加 密 的 方法 很 多 ,其 中 最 
常见 的 方法 有 基于 单 向 函数 、 测 试 模式 . 公 钥 加 密 方案 .平方 剩余 .多 项 式 共享 和 数字 签名 
方案 的 口令 加 密 等 。 经 过 上 述 方法 加 密 的 口令 ,即使 是 系统 管理 员 也 难以 得 到 它 。 

用 户 还 可 采用 一 次 性 用 户口 令 ,也 可 用 便携 式 验证 器 (如 智能 卡 、 磁 卡 和 安全 密码 发 
生 器 等 ) 来 验证 用 户 的 身份 。 网 络 管理 员 应 该 可 以 控制 和 限制 普通 用 户 的 账号 使 用 、 访 问 
网 络 的 时 间 和 方式 。 用 户 名 或 用 户 账号 是 所 有 计算 机 系统 中 最 基本 的 安全 形式 。 用 户 账 
号 应 只 有 系统 管理 员 才 能 建立 。 用 户口 令 应 是 每 位 用 户 访 问 网 络 所 必须 提交 的 “证 件 ”。 
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用 户 可 以 修改 自己 的 口令 ,但 系统 管理 员 应 该 可 以 控制 口令 的 最 小 长 度 , 强 制 修改 口令 的 
时 间 间 隔 、 口 令 的 唯一 性 和 口令 过 期 失效 后 允许 人 网 的 宽 限 次 数 等 。 用 户 名 和 口令 验证 
有 效 之 后 ,再 进一步 履行 用 户 账号 的 默认 限制 检查 。 

2) 网 络 的 权限 控制 

网 络 的 权限 控制 是 针对 网 络 非法 操作 所 提出 的 一 种 安全 保护 措施 。 用 户 和 用 户 组 被 
赋予 一 定 的 权限 ,网 络 控 制 用 户 和 用 户 组 可 以 访问 哪些 目录 、 子 目录 ,文件 或 其 他 资源 , 指 
定 用 户 对 这 些 文件 .目录 和 设备 能 够 执行 哪些 操作 。 受 托 者 指派 和 继承 权限 屏蔽 可 作为 
其 两 种 实现 方式 。 受 托 者 指派 控制 用 户 和 用 户 组 如 何 使 用 网 络 服务 器 的 目录 、 文 件 和 设 
备 。 继 承 权限 屏蔽 相当 于 一 个 过 滤器 ,可 以 限制 子 目录 从 父 目 录 那 里 继承 哪些 权限 。 可 
以 根据 访问 权限 ,将 用 户 分 为 特殊 用 户 ( 即 系统 管理 员 ) ,一般 用 户 和 审计 用 户 ( 负 责 网 络 
的 安全 控制 与 资源 使 用 情况 的 审计 ) 几 类 。 

3) 目录 级 安全 控制 

网 络 应 允许 控制 用 户 对 目录 ,文件 和 设备 的 访问 。 用 户 在 目录 一 级 指定 的 权限 不 仅 
对 所 有 的 文件 和 子 目 录 有 效 ,还 可 进一步 指定 对 目录 下 的 子 目录 和 文件 的 权限 。 对 目录 
和 文件 的 访问 权限 一 般 有 8 种 : 系统 管理 员 权 限 、 读 权限 、 写 权限 、 创 建 权 限 、 删 除权 限 、 
修改 权限 ,文件 查找 权限 和 存 取 控制 权限 。 用 户 对 文件 或 目标 的 有 效 权限 取决 于 用 户 的 
受托 者 指派 用户 所 在 组 的 受托 者 指派 及 继承 权限 屏蔽 取消 的 用 户 权限 三 个 方面 。 一 个 
网 络 系统 管理 员 应 当 为 用 户 指定 适当 的 访问 权限 ,这 些 访 问 权限 控制 着 用 户 对 服务 器 的 
访问 。 这 8 种 访问 权限 的 有 效 组 合 可 以 让 用 户 有 效 地 完成 工作 ,同时 又 能 有 效 地 控制 用 
户 对 服务 器 资源 的 访问 ,从 而 加 强 了 网 络 和 服务 器 的 安全 性 。 

4) 属性 安全 控制 

当 使 用 文件 .目录 和 网 络 设备 时 ,网 络 系统 管理 员 应 给 文件 和 目录 等 指定 访问 属性 。 
属性 安全 控制 可 以 将 给 定 的 属性 与 网 络 服务 器 的 文件 .目录 和 网 络 设备 联系 起 来 。 属 性 
安全 在 权限 安全 的 基础 上 提供 更 进一步 的 安全 性 。 网 络 上 的 资源 都 应 预先 标 出 一 组 安全 
属性 。 用 户 对 网 络 资源 的 访问 权限 对 应 一 张 访问 控制 表 , 用 以 表明 用 户 对 网 络 资源 的 访 
问 能 力 。 属 性 设置 可 以 覆盖 已 经 指定 的 任何 受托 者 指派 和 有 效 权限 。 属 性 往往 能 控制 以 
下 几 个 方面 的 权限 : 向 某 个 文件 写 数据 ,复制 一 个 文件 .删除 目录 或 文件 .查看 目录 和 文 
件 .执行 文件 、 隐 含 文件 和 安全 规则 设 定 共享 等 。 网 络 的 属性 可 以 保护 重要 的 目录 和 文 
件 ,防止 用 户 对 目录 和 文件 的 误 删除 .修改 和 显示 等 。 

5) 网 络 服务 器 安全 控制 

网 络 服务 器 的 安全 控制 包括 可 以 设置 口令 锁定 服务 器 控制 台 , 以 防止 非法 用 户 修改 、 
删除 重要 信息 或 破坏 数据 ,以 及 可 以 设 定 服务 器 登录 时 间 限 制 , 非 法 访问 者 检测 和 关闭 的 
时 间 间 隔 等 。 网 络 服务 器 安全 控制 就 是 在 服务 器 控制 台 上 执行 一 系列 操作 。 

6) 网 络 监测 和 锁定 控制 

网 络 管理 员 应 对 网 络 实施 监控 ,服务 器 应 记录 用 户 对 网 络 资源 的 访问 情况 。 对 非法 
的 访问 请 求 , 服 务 器 应 以 图 形 ,文字 或 声音 等 形式 报警 ,以 引起 网 络 管理 员 注 意 。 如 果 不 
法 之 徒 试 图 进入 网 络 ,网 络 服务 器 应 能 自动 记录 企图 尝试 进入 网 络 的 次 数 ,如 果 非 法 访问 
的 次 数 达 到 了 设 定 的 数值 .那么 该 账号 应 被 自动 锁定 。 

7) 网 络 端 口 和 节点 的 安全 控制 
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网 络 中 服务 器 的 端口 往往 使 用 自动 回 呼 设 备 .静默 调制 解 调 器 加 以 保护 ,并 以 加 密 的 
形式 来 识别 节点 的 身份 。 自 动 回 呼 设备 用 于 防止 假冒 合法 用 户 ,静默 调制 解 调 器 用 以 防 
范 黑 客 的 自动 拨号 程序 对 计算 机 进行 攻击 。 网 络 还 常 对 服务 器 端 和 用 户 端 采取 控制 ,用 
户 必须 携带 证 实 身份 的 验证 器 (如 智能 卡 、 磁 卡 和 安全 密码 发 生 器 等 )。 在 对 用 户 身份 进 
行 验 证 之 后 , 才 允 许 用 户 进入 用 户 端 。 然 后 ,用 户 端 和 服务 器 端 再 进行 相互 验证 。 

8) 防火 墙 控 制 

防火 墙 是 发 展 较 快 .使 用 较 广 的 一 种 提供 网 站 安全 的 技术 性 措施 。 它 以 路 由 器 或 保 
全 主机 的 形式 建立 阻隔 内 外 网 的 屏障 ,通过 软件 设置 IP 通信 的 安全 策略 ,使 网 站 能 在 提 
供 服务 的 前 提 下 还 能 抵挡 外 部 的 侵入 。 事 实 上 ,超过 1/3 的 网 站 是 由 某 种 形式 的 防火 墙 
加 以 保护 的 ,这 是 对 黑客 防范 最 严 .安全 性 最 强 的 一 种 方式 ,任何 关键 性 的 服务 器 都 放 在 
防火 墙 之 后 。 

3. 数据 加 密 策略 

加 密 的 目的 是 保护 网 内 的 数据 文件 .口令 和 控制 信息 ,保护 网 上 传输 的 数据 。 加 密 
常用 的 方法 有 链 路 加 密 、 端 点 加 密 和 节点 加 密 三 种 。 链 路 加 密 的 目的 是 保护 网 络 节点 之 
间 的 链 路 信息 安全 ,端点 加 密 的 目的 是 对 源 端 用 户 到 目的 端 用 户 的 数据 提供 保护 ,节点 加 
密 的 目的 是 对 源 节点 到 目的 节点 之 间 的 传输 链 路 提供 保护 。 用 户 可 根据 网 络 情况 酌情 选 
择 上 述 加 密 方式 。 信 息 加 密 过 程 由 形形色色 的 加 密 算法 来 具体 实施 , 它 以 很 小 的 代价 提 
供 很 大 的 安全 保护 。 在 多 数 情况 下 ,信息 加 密 是 保证 信息 机 密 性 的 唯一 方法 。 

据 不 完全 统计 ,到 目前 为 止 , 已 经 公开 发 表 的 各 种 加 密 算法 多 达 数 百 种 。 如 果 按 照 收 
发 双方 密 钥 是 否 相 同 来 分 类 ,可 以 将 这 些 加 密 算法 分 为 常规 密码 算法 和 公 钥 密码 算法 两 
种 。 在 常规 密码 中 , 收 信 方 和 发 信 方 使 用 相同 的 密 钥 . 即 加 密 密 钥 和 解密 密 钥 是 相同 或 等 
价 的 ; 公 钥 密码 的 收 信 方 和 发 信 方 使 用 不 同 的 密 钥 。 

常规 密码 和 公 角 密码 相 比 较 , 哪 个 更 安全 些 ? 

不 能 简单 地 说 哪个 更 好 ,哪个 更 安全 ,它们 各 有 自己 的 特点 。 常 规 密码 的 优点 是 有 很 
强 的 保密 强度 , 且 能 经 受 住 时 间 的 检验 和 攻击 ,但 其 密 钥 必须 通过 安全 的 途径 传送 。 因 
此 ,其 密 钥 管理 成 为 系统 安全 的 重要 因素 。 公 铀 密码 的 优点 是 可 以 适应 网 络 的 开放 性 要 
求 , 且 密 钥 管 理 问题 也 较为 简单 ,尤其 可 方便 地 实现 数字 签名 和 验证 。 但 其 算法 复杂 ,加 
密 数 据 的 速率 较 低 。 尽 管 如 此 , 随 着 现代 电子 技术 和 密码 技术 的 发 展 , 公 钥 密码 算法 将 是 
一 种 很 有 前 途 的 网 络 安全 加 密 体 制 。 


当然 ,在 实际 应 用 中 ,人 们 通常 将 常规 密码 和 公 钥 密码 结合 在 一 起 使 用 。 例 如 利用 DES 
或 者 IDEA 来 加 密 信息 ,而 采用 RSA 来 传递 会 话 密 钥 。 如 果 按 照 每 次 加 密 所 处 理 的 位 来 分 
类 , 则 可 以 将 加 密 算法 分 为 序列 密码 和 分 组 密码 两 种 。 前 者 每 次 只 加 密 一 位 ;而 后 者 则 是 先 
将 信息 序列 分 组 ,每 次 加 密 一 个 分 组 。 可 以 说 .如何 加 密 是 当前 研究 的 热门 话题 。 

4. 网 络 安全 管理 策略 

在 网 络 安全 中 ,除了 采用 上 述 技术 措施 之 外 ,加 强 网 络 的 安全 管理 ,制定 有 关 规 章 制 
度 , 对 于 确保 网 络 安全 和 可 靠 地 运行 将 起 到 十 分 重要 的 作用 。 网 络 的 安全 管理 策略 包括 
确定 安全 管理 等 级 和 安全 管理 范围 ,制定 有 关 网 络 操作 使 用 规程 和 人 员 出 人 机 房管 理 制 
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度 ,以 及 制定 网 络 系统 的 维护 制度 和 应 急 措施 等 。 
7.1.8 ASP.NET 中 的 安全 性 


在 ASP. NET 中 讨论 安全 性 首先 要 解决 两 个 问题 , 那 就 是 谁 有 权利 进入 系统 ? 他 进 
入 系统 之 后 能 进行 何 种 操作 ? 在 解决 谁 能 进入 系统 的 问题 中 ,通常 会 维护 一 张 允许 进入 
系统 的 用 户 的 名 单 , 当 用 户 要 求 进入 系统 时 ,判断 他 是 否 是 合法 用 户 。 这 样 一 来 ,问题 就 
转化 为 如 何 有 效 地 判别 一 个 用 户 是 否 是 系统 的 有 效用 户 ,我 们 称 之 为 “验证 ”过 程 。 一 个 
常见 的 验证 过 程 是 ,进入 某 些 系统 时 被 要 求 输 入 用 户 名 和 口令 。 当 用 户 进入 以 后 ,我 们 只 
允许 他 访问 事先 指定 给 他 的 资源 ,这 一 过 程 称 为 “授权 ”。 只 有 通过 授权 检查 后 ,用户 才能 
够 对 相应 资源 进行 操作 。 在 ASP. NET 环境 中 ,ASP. NET 和 IIS 结合 在 一 起 为 用 户 提 
供 验 证 和 授权 服务 。 

ASP. NET 的 应 用 程序 还 可 以 根据 进入 用 户 的 不 同 标识 ,执行 相应 不 同 的 应 用 代码 。 
这 种 方式 被 称 为 “角色 扮演 (impersonation)”。 

在 一 些 应 用 中 ,对 于 不 同 的 用 户 所 能 够 看 到 和 执行 的 功能 是 不 尽 相同 的 ,这 就 要 求 
ASP. NET 提供 “角色 (role)” 和 “用 户 (user)” 的 区 分 方法 。 

1. 验证 和 授权 

ASP. NET 和 IIS 一 起 为 用 户 提供 验证 服务 ,用 户 验证 方式 有 三 种 , 即 基本 验证 方式 
(basic) ,简要 验证 方式 (digest) 和 窗口 验证 方式 (window)。 同 时 ,ASP. NET 支持 微软 公 
司 的 “护照 (passport) ”验证 服务 , 它 单方 面 提供 签到 服务 和 用 户 描 述 服 务 。 

此 外 ,ASP. NET 还 提供 了 Cookies, 帮 助 建立 一 种 基于 用 户 Form 的 验证 方式 。 通 
过 Cookies, 用 户 的 应 用 程序 可 以 用 自己 的 代码 和 逻辑 实现 用 户 定义 的 可 信 性 验证 。 

由 于 ASP.NET 的 验证 服务 是 建立 在 IIS 的 验证 服务 之 上 的 ,因此 在 设立 自己 的 应 
用 服务 时 有 时 需要 在 IIS 中 进行 相应 的 设置 。 例 如 ,为 实现 ASP. NET 的 基本 验证 服务 ， 
就 必须 利用 Internet Service Tool 工具 把 该 应 


用 设置 成 基本 鉴别 服务 方式 。 ee 
具体 方法 如 下 。 ee [Er | 
选择 “开始 ”一 “程序 ”一 “管理 工具 ”一 | 一 me 

“Internet 信息 服务 器 ”选项 ,打开 “上 默认 Web 人 

站 点 ”, 选 择 所 需 的 应 用 站 点 。 EH en 
右 击 和 鼠标 ,从 弹出 的 快捷 菜单 中 选择 “ 属 i 的 全 

性 ”命令 ,再 从 对 话 框 中 选择 “目录 安全 性 ” 选 | 国生 0 

项 卡 。 在 “匿名 访问 和 验证 控制 " 框 中 , 单 击 A EY 

“编辑 "按钮 。 然 后 在 出 现 的 “验证 方法 "窗口 | ms ani 一 一 

中 ,选择 “验证 访问 " 框 中 的 “基本 验证 " 复 选 i 已 ED i 


框 。 最 后 单 击 “ 确 定 "按钮 ,就 完成 了 设置 基本 - 
验证 方法 。 操 作 的 画面 如 图 7-1 所 示 。 人 
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要 使 ASP. NET 的 验证 机 制 生 效 , 需 要 对 应 用 的 配置 文件 config. Web 进行 设置 。 设 置 
验证 需要 包含 在 一 security 之 和 一 / security 二 标识 之 间 。 它 使 用 一 authentication mode 一 必 …" 
二 语法 形式 ,其 中 mode 属性 指定 了 验证 采用 的 方式 。 具 体 的 验证 模式 如 表 7-1 所 示 。 

表 7-1 ASP. NET 的 验证 模式 


模 式 描 述 
None 没有 任何 ASP. NET 的 验证 服务 被 激活 
i ASP. NET 和 Windows 的 机 制 一 起 配合 使 用 ,可 以 授权 限制 Windows NT 的 
eo 用 户 和 工作 组 的 访问 
ASP. NET 验证 服务 可 以 管理 Cookies, 可 以 引导 使 一 个 未 经 授权 的 用 户 去 登 
Cookie 录 网 页 。 这 种 模式 经 常 和 IIS 一 起 配合 使 用 ,可 以 让 一 个 匿名 用 户 去 访问 应 
用 程序 
Be ASP. NET 验证 服务 通过 使 用 护照 (passport) 服务 软件 包 , 附 属 在 服务 的 外 
Pp 层 ,更 加 强 了 验证 服务 ,这 种 软件 包 必须 安装 到 系统 中 才能 使 用 


举例 来 说 ,使 用 Cookie 验证 方式 对 某 个 应 用 进行 验证 ,那么 在 其 应 用 的 配置 文件 
config. Web 中 ,应 该 包括 以 下 几 行 。 


<!--config.Web- -> 
<configuration> 

<Security> 

<authentication mode= "Cookie"/> 
</Security > 

</configuration > 


ASP. NET 提供 了 两 种 授权 方式 : 基于 ACL、 资 源 权限 的 授权 方式 和 URL 授权 方 
式 。 基 于 ACL 和 资源 权限 的 授权 方式 有 点 类 似 于 UNIX 下 的 文件 权限 检查 ,不 过 它 更 
加 严格 和 完备 。 当 用 户 请 求 某 个 页 面 时 ,ASP. NET 检查 该 页 面 的 ACL( 访 问 控制 列表 ) 
和 该 文件 的 权限 ,看 该 用 户 是 否 有 权限 读 取 该 页 面 。 若 有 . 则 该 页 面 称 作 * 已 授权 ”。 这 种 
授权 方式 主要 通过 系统 管理 员 对 文件 的 权限 的 设 定 来 实现 。 

而 URL 授权 方式 ,对 于 某 个 用 户 的 页 面 请 求 , 并 不 是 从 文件 权限 出 发 ,而 是 根据 系 
统 的 配置 情况 ,来 决定 用 户 的 请 求 是 否 是 经 过 授权 的 。URL 授权 方式 的 实现 通常 是 通过 
设置 应 用 配置 文件 config. Web 中 关于 授权 和 角色 的 配置 来 实现 的 。 

1) 基于 Windows 的 验证 

当 采 用 基于 Windows 方式 的 验证 后 (一 authentication mode 一 "windowsY 二 ),ASP. 
NET 对 每 一 个 页 面 请 求 产 生 一 个 对 象 . 这 个 对 象 可 以 被 URL 授权 方式 用 来 进行 授权 ,或 
者 被 用 户 程序 用 来 判断 是 否 是 某 种 角色 。 

例如 ,判断 当前 用 户 是 否 是 管理 员 ,可 以 采用 以 下 的 代码 。 
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If User.IsInRole("Administrator") 


// 如 果 是 管理 员 组 成 员 ,… 


Else 
// 如 果 不 是 管理 员 组 成 员 ,… 


End If 


可 能 用 户 希 望 对 验证 过 程 加 入 一 些 自己 的 控制 代码 ,那么 就 需要 对 WindowsPrinci- 
pal 对 象 的 WindowsAuthentication_OnAuthenticate 事件 做 出 自己 的 处 理 ,编写 自己 的 
消息 处 理 函 数 。 通 常用 户 通 过 实现 System. Principal. Iprincipal 类 完成 。 

2) 基于 FORM 的 验证 

基于 FORM 的 验证 ,实际 上 是 允许 应 用 程序 定义 自己 的 验证 画面 和 可 信 性 验证 。 当 
用 户 进入 时 ,出 现 事先 定义 的 画面 并 要 求 输入 验证 要 素 。 输 入 完毕 ,用 户 逻 辑 对 输入 进行 
验证 , 若 通过 , 则 进入 应 用 ,和 否则 返回 起 始 输 入 画面 。 基 于 FORM 的 验证 ,通常 都 采用 
Cookies 技术 来 实现 验证 任务 。 启 用 基于 FORM 的 验证 ,是 在 config. Web 中 设置 二 au- 
thentication mode 一 "ookiey 过 来 实现 的 。 

例如 ,采用 基于 FORM 的 验证 方式 ,拒绝 匿名 用 户 进 入 的 配置 段 如 下 。 


<!-—-config.Web- -> 
<configuration> 
<security> 
<authentication mode="Cookie"/> 
<authorization> 
<deny users="?"/> 
</ authorization> 
</ security> 
</ configuration> 


其 中 ,二 authorization 一 一 节 中 ,用 标识 表示 禁止 某 种 用 户 ,“?” 代 表 匿 名 用 户 ,“*” 

代表 所 有 用 户 。 当 然 , 在 users 后 也 可 以 跟 指定 的 用 户 ,表示 只 拒绝 指定 的 用 户 。 

此 外 ,在 配置 节 中 还 有 一 个 Cookie 标识 , 它 规定 了 Cookie 的 行为 ,也 较为 重要 。 

Cookie 标识 有 如 下 三 个 属性 。 

。 decryptionkey: 用 于 指定 对 Cookie 加 解密 的 密 钥 。 如 果 不 指定 或 指定 为 auto- 
generate, 密 钥 将 采用 Crypto API 产生 的 系统 密 钥 。 当 指定 为 autogenerate 时 ， 
产生 的 密 钥 和 机 器 相关 ,因而 不 能 跨 机 器 和 平台 ,除非 显示 给 出 密 钥 。 

。 loginurl: 验证 页 面 。 当 用 户 验证 失败 后 被 定向 到 的 页 面 , 它 可 以 是 在 本 地 ,也 可 
以 是 在 其 他 机 器 上 。 

。 Cookie: 指定 用 于 验证 任务 的 Cookie 的 名 字 。 由 于 在 同一 台 机 器 上 可 能 存在 多 
个 应 用 ,而 同一 应 用 使 用 一 个 Cookie 名 ,所 以 同一 台 机 器 上 的 Cookie 名 字 不 能 
相同 。 
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例如 ,在 config. Web 中 有 如 下 定义 。 


<!--config.Web- -> 
<security> 
<authentication mode= "Cookie"> 
<cookie decryptionkey= "autogenerate" loginurl="login.aspx" cookie=".ASPXCOOKIE- 
DEMO™ 
/> 
</ authentication> 
</security> 


从 这 段 配置 可 以 知道 ,Cookie 的 密 钥 由 系统 产生 , 当 验 证 失败 后 ,页 面 将 跳 转 至 log- 
in. aspx，Cookie 名 为 . ASPXCOOKIEDEMO。 

在 基于 Form 的 验证 中 ,一 个 常用 到 的 对 象 是 CookAuthentication 。 

CookAuthentication 有 4 个 比较 重要 的 方法 。 

。， RedirectFormLoginPage 方法 : 通常 在 验证 成 功 以 后 ,从 用 户 的 验证 页 面 返回 开 

始 请 求 的 页 面 。 它 带 有 两 个 参数 ,第 一 个 为 Cookie 要 记录 的 用 户 名 ,第 二 个 表明 
是 否 记录 到 永久 性 Cookie 中 。 

例如 ,CookAuthentication。RedirectFormLoginPage("Dan" True) 表 示 把 用 户 Dan 
记录 到 硬盘 上 的 Cookie 记录 中 ,然后 跳 转 到 用 户 原先 请 求 的 页 面 上 。 

。 GetAuthCookie: 从 Cookie 中 取得 指定 用 户 名 的 值 。 它 的 参数 和 RedirectForm- 

LoginPage 方法 是 一 样 的 。 

例如 ,CookAuthentication，GetAuthCookie('Dan", False) 表 示 从 当前 连接 的 Cookie 
中 取出 用 户 名 为 Dan 的 值 。 

。 SetAuthCookie: 把 指定 用 户 名 存 入 Cookie 中 。 参 数 和 GetAuthCookie 方法 

一 致 。 

例如 ,CookAuthentication。SetAuthCookie("Dan" False) 表 示 把 用 户 Dan 记录 到 连 
接 过 程 中 存在 的 Cookie 中 。 

。 SignOut: 删除 当前 用 户 的 验证 Cookie, 它 不 会 理会 到 底 是 在 内 存 还 是 在 硬盘 上 。 

2. 授权 用 户 和 角色 

URL 授权 控制 对 资源 的 访问 权限 。 它 可 以 使 一 些 用 户 和 和 角色 对 资源 有 存 取 权限 ,也 
可 以 拒绝 某 些 用 户 和 角色 对 资源 的 存 取 , 甚 至 还 可 以 决定 能 够 存 取 资源 的 HTTP 方法 
(例如 ,不 允许 get, 人 允许 POST 等 ) 。 

对 于 授权 用 户 和 角色 的 控制 ,ASP. NET 通过 配置 文件 config. Web 中 的 二 authori- 
zation 之 标识 段 来 实现 。 一 allow 二 标识 表示 人 允许 对 资源 的 访问 ,二 deny 二 标识 表示 拒绝 
对 资源 的 访问 。 

它们 都 有 两 个 属性 ,users 和 roles 分 别 表 示 用 户 和 和 角色。 

下 面 来 看 一 个 实例 。 
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它 表明 了 这 样 一 个 事实 ,用 户 nobody@163. net 和 角色 Admins 有 访问 本 站 点 的 权 
限 , 其 他 用 户 对 本 站 点 的 访问 将 被 拒绝 。 也 就 是 用 户 nobody@163. net 和 角色 Admins 
分 别 是 授权 用 户 和 授权 角色 。 

同样 ,可 以 定义 多 个 用 户 或 者 角色 被 授权 或 禁止 ,它们 之 间 以 “,” 分 隔 。 

例如 : 


表示 用 户 Dan,Li, Wang 是 授权 用 户 , 但 是 角色 为 Admins 或 者 是 Everyone 的 被 排 
除 在 外 。 它 的 效果 和 分 开 写 是 一 样 的 ,如 上 例 也 可 以 写 为 : 


此 外 ,还 可 以 决定 用 户 的 某 种 HTTP 方法 是 否 可 以 被 允许 ,方法 是 使 用 verb 属性 来 
表明 对 那 种 HTTP 方法 操作 。 
例如 各 


表示 人 允许 用 户 Dan,Li 采 用 post 方法 访问 资源 ,而 拒绝 角色 everyone 的 get 方式 对 
资源 的 访问 。 

符号 ”x* ”和 *?" 在 一 allow 过 和 王 deny 之 标识 中 有 特殊 的 含义 “* ”表示 任何 用 户 ， 
“?” 表 示 匿 名 用 户 。 

例如 : 
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<authorization> 
<allow users="# "> 
<deny users= "? "> 


</authorization > 


表示 除了 匿名 用 户 以 外 的 所 有 用 户 都 被 允许 访问 本 站 点 。 

配置 文件 也 呈 层 次 结构 ,这 也 就 导致 了 用 户 和 角色 的 授权 不 是 单一 的 结果 , 它 取决 于 
沿 树 形 结构 上 所 有 配置 文件 指定 的 结果 的 合集 ,而 且 越 接近 叶 节 点 的 配置 越 有 效 。 

例如 ,访问 http: www. my. com/MyApp/a.aspx。 在 http: www. my. com 根 目 录 下 
的 配置 文件 config. Web 有 如 下 内 容 。 


<security> 
<authorization> 
<allow users="* "> 
< /authorization> 
</security> 


而 在 MyApp 目录 下 有 配置 文件 config. Web, 内 容 如 下 。 


<security> 

<authorization> 
<allow users= "Dan"> 

<deny users="* "/> 

< /authorization> 

</security> 


那么 ,授权 用 户 的 集合 到 底 是 怎样 的 呢 ? ASP. NET 首先 取得 站 点 根 目录 下 的 配置 ， 
即 所 有 用 户 都 被 允许 访问 ;然后 ASP. NET 进入 MyApp 的 目录 并 取得 其 下 的 配置 , 除 用 
户 Dan 以 外 所 有 的 用 户 被 拒绝 ;最 后 合并 两 个 授权 集合 ,并 且 如 果 两 者 之 间 有 冲突 ,以 后 
者 为 准 。 所 以 最 终 的 授权 集合 为 用 户 Dan, 其 他 用 户 被 拒绝 。 


7.2 网 站 的 维护 


网 站 建 好 后 并 不 是 一 劳 永 逸 的 ,还 需要 精心 地 运作 才 会 显现 成 效 。 网 站 是 企业 虚拟 
的 办 公 地 点 ,所 以 理 所 应 当 有 人 看 管 , 网 站 管理 员 就 是 监 守 网 站 这 个 虚拟 办 公 室 的 人 员 。 
他 是 网 站 的 用 户 和 合作 伙伴 等 一 切 网 站 来 客 的 联络 人 .同时 又 肩负 着 这 个 虚拟 办 公 室 的 
日 常 运营 及 维护 的 重任 。 网 站 管理 员 , 顾 名 思 义 就 是 管理 网 站 的 人 。 就 网 站 的 特殊 性 而 
言 , 它 好 比 是 企业 运营 的 电子 版 ,只 有 不 断 地 进行 建设 维护 和 更 新 ,才能 与 企业 的 发 展 同 
步 。 网 站 建成 以 后 一 定 要 设置 网 站 管理 人 员 , 它 不 仅 包括 Webmaster, 而且 包 括 所 有 的 
技术 人 员 和 网 页 日 常 维护 人 员 。 
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7.2.1 设置 网 站 管理 员 


1. 设置 网 站 管理 员 的 必要 性 

1) 能 及 时 与 网 站 来 客 保持 联系 

一 些 企业 网 站 设立 后 ,网 站 所 设置 的 电子 信箱 一 直 没有 正常 使 用 或 多 人 使 用 ,没有 发 
挥 电子 邮箱 应 有 的 作用 。 要 知道 ,用 户 访问 了 网 站 后 ,如 对 某 些 方面 感 兴趣 ,往往 会 写 个 
留言 .发 封 邮 件 。 这 些 网 站 来 客 就 很 可 能 是 潜在 的 客户 群 ,应 该 给 予 必要 的 重视 ,对 他 们 
提出 的 问题 及 时 解决 并 回复 。 这 不 仅 有 助 于 企业 建立 良好 的 公众 形象 ,而 且 能 进一步 增 
加 网 站 回头 客 的 数量 。 反 之 ,如 果 没 有 专人 负责 处 理 网 站 来 客 邮 件 信息 的 话 ,这 些 网 站 来 
客 的 留言 或 电子 邮件 不 是 发 不 出 去 就 是 发 信 后 石沉大海 , 迟 迟 得 不 到 回复 。 而 且 根据 经 
验 ,尽管 网 站 上 有 地 址 .电话 和 传真 号 码 等 ,但 访问 者 还 是 喜欢 用 电子 邮件 联系 ,因为 网 站 
本 身 就 是 突出 这 种 通信 优势 。 所 以 要 保持 网 站 与 访问 者 能 及 时 沟通 ,就 必须 设置 网 站 管 
理 员 。 

2) 能 对 网 站 进行 日 常 的 技术 管理 

一 些 网 站 在 建站 初期 ,未 能 将 信息 全 部 组 织 到 位 ,这 种 情况 是 很 常见 的 。 关 键 是 要 在 
建站 之 后 ,不 断 对 网 站 的 内 容 进行 更 新 和 补充 ,并 且 维 护 好 历史 资料 。 如 果 过 了 很 长 一 段 
时 期 后 依然 内 容 干 巴巴 ,从 不 更 新 ,甚至 链接 断层 界面 零乱 文件 丢 缺 ,一 派 衰落 景象 的 
话 , 只 会 使 辛 辛 苦 苦 建 起 的 网 站 变 成 垃圾 ,也 就 谈 不 上 对 客户 提供 必要 的 服务 了 。 因 此 网 
络 不 能 被 孤立 地 对 待 ,必须 将 其 作为 企业 的 一 个 部 分 。 对 于 一 个 信息 化 的 企业 来 说 ,网 络 
就 是 业务 ,人 们 必须 从 业务 的 角度 来 看 待 网 络 管理 ,高 效率 的 网 络 管理 手段 是 业务 成 长 的 
保障 。 

3) 能 对 网 站 安全 进行 监控 

网 站 是 对 外 开放 的 ,每 个 来 客 都 能 进行 访问 ,因此 要 注意 网 站 的 安全 问题 。 要 防止 某 
些 心怀 不 轨 的 来 客 对 网 站 进行 攻击 ,修改 网 页 搞 恶 作 剧 .破坏 系统 程序 或 施放 病毒 使 系统 
陷 人 瘫痪 ,盗用 服务 器 磁盘 空间 建立 自己 的 个 人 主页 或 兴趣 站 点 ,传播 黄色 、 反 动 信息 , 窃 
取 政 治 .军事 \ 商 业 秘密 ,进行 电子 邮件 骚扰 及 转移 资金 账户 等 。 这 就 需要 网 站 的 管理 员 
对 网 站 进行 严密 的 防护 ,设置 防火 墙 , 采 用 加 密 算 法 进行 密 钥 传输 和 用 户 身份 认证 ,并 能 
及 时 发 现 网 站 的 漏洞 子 以 处 理 。 

寻找 网 络 中 的 薄弱 环节 和 安全 漏洞 是 每 个 系统 管理 员 和 每 个 黑客 都 在 做 的 一 件 事 。 
系统 管理 员 只 有 能 够 检测 并 发 现 它 的 所 在 , 才 有 可 能 控制 它 ,才能 领先 黑客 一 步 。 另 一 方 
面 ,网 络 是 动态 的 ,黑客 也 是 多 谋 善 变 的 。 买 安全 产品 或 服务 , 仅 配置 一 次 是 不 够 的 ,防火 
墙 如 此 ,其 他 安全 产品 也 是 如 此 。 

2. 网 站 管理 员 的 设置 原则 

网 站 管理 员 的 设置 原则 是 多 种 多 样 的 ,有 的 是 按照 板块 设置 管理 员 , 如 财经 板块 、 体 
育 板块 等 ,这 种 设置 适用 于 内 容 丰富 全 面 的 大 型 站 点 。 有 的 是 根据 技术 差异 角度 设置 管 
理 员 , 如 系统 管理 员 ,数据 库 管理 员 和 普通 管理 员 等 ,这 种 设置 适用 于 对 安全 性 要 求 较 高 
的 站 点 。 现 行 的 做 法 是 多 样 的 ,最 根本 的 一 个 原则 就 是 要 结合 网 站 管理 的 需要 设置 管 
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理 员 。 

3. 确立 制度 

确立 和 完善 管理 制度 是 网 站 管理 的 客观 要 求 。 网 站 管理 员 只 有 在 明确 其 工作 职责 、 
工作 内 容 及 需要 掌握 的 相关 技能 后 ,才能 有 的 放 矢 地 开展 工作 ,以 达到 良好 的 效果 。 

4. 明确 工作 职责 

综 上 所 述 , 网 站 管理 员 的 工作 是 非常 重要 的 ,所 以 管理 员 要 认真 履行 各 项 规章 制度 ， 
对 所 管理 的 工作 抓 好 抓 实 。 同 时 管理 员 有 义务 为 网 站 的 发 展 和 规划 提供 良好 的 建议 。 网 
站 管理 人 员 的 主要 责任 是 : 进行 网 站 的 更 新 维护 ,与 企业 各 有 关 部 门 紧密 联系 ,及 时 编辑 
和 组 织 网 站 相关 信息 内 容 ,保持 网 站 处 于 一 种 活力 状态 下 而 成 为 信息 反馈 的 中 枢 , 每 天 检 
查 网 站 的 运作 情况 和 通信 情况 并 及 时 处 理 。 


7.2.2 网 站 维护 的 主要 内 容 


网 站 的 管理 维护 主要 包括 检测 网 站 的 错误 ,保证 网 站 正常 运转 、 人 处 理 用 户 信 息 、 定 期 
更 新 网 页 内 容 和 修正 网 页 错误 ,确认 网 页 的 程序 和 链接 的 正确 性 、 跟 踪 访 问 者 的 信息 , 清 
楚 网 站 的 点 击 状况 、 备 份 动态 数据 库 等 。 对 于 公司 企业 等 单位 ,尤其 是 拥有 自己 服务 器 
的 单位 , 则 需要 配置 专门 的 网 站 管理 员 。 

企业 网 站 中 最 常见 的 更 新 包括 公司 新 闻 的 发 布 新 产品 的 推出 、 公 司 举办 的 各 种 名 目 
的 活动 及 网 上 答疑 等 ,这 些 都 需要 在 公司 站 点 上 实时 体现 。 当 然 ,网 站 的 维护 工作 还 有 许 
多 ,不 过 最 主要 的 目的 还 在 于 评估 所 建 网 站 的 运行 情况 ,及 时 知道 访 者 的 反馈 信息 ,分 析 
情况 ,以 便 为 公司 的 发 展 及 网 站 的 运营 作为 参考 依据 。 

在 Web 站 点 上 履行 维护 工作 到 底 是 谁 的 责任 ,这 个 问题 很 难 回答 。 大 公司 经 常 把 工 
作 转 包 给 顾问 或 其 他 公司 ,小 公司 有 时 把 任务 加 到 现 有 雇员 的 职责 中 。 对 一 般 用 户 而 言 ， 
可 以 雇用 一 个 公司 集中 完成 Web 站 点 上 特定 的 维护 工作 。 

1. 网 站 内 容 的 维护 和 更 新 

网 站 的 信息 内 容 应 该 适时 地 更 新 。 在 网 站 栏目 的 设置 上 ,最 好 将 一 些 可 以 定期 更 新 
的 栏目 如 企业 新 闻 等 放 在 首页 上 ,使 首页 的 更 新 频率 更 高 些 。 此 外 , 当 网 站 变 得 十 分 庞大 
时 将 会 有 不 计 其 数 的 图 片 和 网 页 文件 等 内 容 , 如 果 它们 有 一 个 丢失 或 链接 失败 都 会 引起 
网 页 错误 ,所 以 一 定 要 保证 整个 网 站 的 “健康 ”和 完整 。 这 就 是 狭义 的 维护 概念 。 网 页 更 
新 要 做 到 以 下 几 点 。 

1) 专人 维护 新 闻 栏 目 

这 是 非常 重要 的 。 一 方面 把 企业 、 业 界 动态 都 反映 在 里 面 .让 访问 者 觉得 这 是 一 个 发 
展 中 的 企业 ; 另 一 方面 ,要 在 网 上 及 时 收集 相关 材料 放置 到 网 站 上 ,以 引起 同类 用 户 的 
兴趣 。 

2) 时 常 检查 相关 链接 

通过 测试 软件 对 网 站 所 有 的 网 页 链接 进行 测试 ,看 是 否 能 连通 ,尤其 是 网 站 导航 栏目 
可 能 经 常 出 问题 。 最 好 是 自己 亲自 浏览 ,这样 才 能 及 时 发 现 问题 。 也 可 以 在 网 页 上 显示 
“如 有 链接 错误 ,请 指出 ”等 字样 。 
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2. 定期 检测 网 站 ,保证 服务 器 的 正常 工作 

这 是 管理 网 站 最 基本 的 工作 之 一 。 如 果 是 自己 公司 的 服务 器 ,就 需要 保证 服务 器 的 
正常 工作 ,保证 网 络 的 正常 运转 ,保证 用 户 可 以 正常 地 访问 网 站 并 使 用 网 站 上 提供 的 各 种 
服务 等 ,这 需要 懂得 一 定 技术 的 人 员 来 担任 网 站 管理 工作 。 如 果 是 租用 的 虚拟 主机 或 个 
人 申请 的 免费 网 页 空间 , 则 只 需要 定期 检测 网 站 ,保证 正常 运转 ,检查 并 修正 网 页 错误 


即 可 。 
按照 网 站 的 规模 大 小 ,这 些 工 作 都 需要 借助 一 些 工 具 软 件 来 完成 ,读者 可 参考 一 些 这 
方面 的 其 他 书籍 。 


这 是 所 有 管理 维护 工作 的 基础 ,具有 良好 的 稳定 性 是 一 个 网 站 生存 的 必要 条 件 。 试 
想 一 下 ,一 个 总 是 包含 错误 的 链接 ,导致 网 页 无 法 打开 ,或 者 总 是 跳出 烦人 的 页 面 错 误 窗 
口 的 网 站 ,会 有 持久 的 生命 力 吗 ? 如 果 这 是 公司 的 网 站 , 则 会 严重 影响 到 公司 的 形象 ,用 
户 不 但 会 不 满意 公司 的 服务 质量 ,甚至 会 怀疑 公司 的 实力 ,公司 会 因此 失去 不 少 的 用 
户 群 。 

因此 ,在 保证 网 站 畅通 无 阻 .正常 运作 的 前 提 下 , 才 可 进一步 地 运行 网 站 的 维护 和 
改进 。 

3. 处 理 网 站 数据 和 用 户 信息 

网 站 建设 好 以 后 ,下 一 步 的 工作 就 是 研究 如 何 发 展 网 站 ,在 这 里 充分 利用 一 些 网 站 数 
据 和 用 户 的 反馈 信息 ,可 以 使 工作 达到 事半功倍 的 效果 。 

1) 处 理 、 分 析 网 站 数据 

在 构建 网 站 时 ,可 以 在 网 页 上 加 载 计数 器 或 者 使 用 访问 日 志 , 这 些 都 有 利于 帮助 分 析 
网 站 的 情况 以 便于 进一步 的 发 展 。 

计数 器 是 用 来 统计 访问 网 页 人 数 的 工具 ,在 首页 上 放置 计数 器 即 可 统计 出 网 站 的 访 
问 量 。 许 多 提供 虚拟 主机 、 免 费 空间 的 网 站 都 提供 计数 器 ,也 可 以 到 一 些 提 供 统计 服务 的 
网 站 获得 这 项 服务 。 下 面 是 几 个 提供 计数 统计 服务 的 网 站 。 

。 天 堂 免费 计数 器 (http://www. xcinfo. ha. cn/jsq/login. asp) 

» FoxWeb(http://www. foxweb. com) 

许多 提供 计数 统计 的 网 站 除了 能 够 提供 访问 量 外 ,还 能 够 提供 开始 统计 日 期 \ 总 统计 
天 数 、 总 浏览 人 数 \ 日 访问 量 、 预 计 本 日 浏览 人 数 、 各 栏目 访问 量 、 站 点 性 质 和 总 排名 等 服 
务 , 可 以 根据 这 些 数据 及 时 调整 网 站 的 各 个 栏目 .制定 下 一 步 的 网 站 发 展 计划 等 。 

访问 日 志 是 用 来 记录 用 户 在 网 站 进行 各 种 操作 的 ,最 初 的 访问 日 志 是 用 来 维护 简单 
的 用 户 请 求 信息 ,后 来 经 过 逐步 扩展 ,包含 了 诸如 浏览 者 来 自 哪 里 ,浏览 者 使 用 的 浏览 器 
类 型 .用户 最 先 浏览 的 网 页 、 用 户 最 后 浏览 的 网 页 .访问 最 多 的 网 页 ,访问 最 少 的 网 页 和 下 
载 次 数 最 多 的 文件 等 。 这 些 数据 会 对 管理 者 要 做 的 分 析 带 来 很 大 的 帮助 ,这样 可 以 有 计 
划 地 调整 网 站 ,哪些 地 方 应 该 加 强 ,哪些 地 方 应 该 删除 等 。 对 访问 日 志 的 数据 分 析 一 般 使 
用 专门 的 软件 ,如 WebTrends Log Analyzer 等 。 

2) 处 理 用 户 信 息 

通常 一 个 网 站 建 好 后 ,网 站 管理 者 除了 要 日 常 维护 站 点 之 外 ,还 必须 与 访问 者 多 沟 
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通 。 仅 仅 有 精美 的 网 站 设计 、 先 进 的 技术 应 用 及 丰富 的 内 容 , 访 问 量 不 一 定 会 上 升 。 在 产 
品 销售 生产 中 ,一 般 应 先 做 市 场 调查 ,看 看 市 场 上 人 们 需要 什么 样 的 产品 ,然后 才 开始 生 
产 。 产 品 推出 后 ,还 要 收集 反馈 信息 ,对 产品 进行 改造 ,进一步 迎合 客户 的 需要 。 站 点 建 
设 也 同 产 品 销售 一 样 ,必须 同 站 点 访问 者 多 交流 .这样 才能 了 解 网 民 需 要 看 什么 。 如 果 不 
了 解 访问 者 的 想法 ,只 是 按照 自己 的 思路 去 发 展 , 那 么 站 点 只 能 是 空中 楼 阁 。 

企业 应 设 专人 或 专门 的 岗位 从 事 网 站 的 服务 和 反馈 处 理工 作 。 客 户 向 企业 网 站 提交 
的 各 种 反馈 表单 .购买 的 商品 发 到 企业 邮箱 中 的 电子 邮件 ,以 及 在 企业 留言 板 上 的 留言 
等 ,企业 如 果 没 有 及 时 处 理 和 跟 进 , 则 不 但 会 丧失 机 会 ,还 会 造成 很 坏 的 影响 。 

因特网 之 所 以 能 够 迅猛 地 发 展 , 除 了 它 能 为 用 户 带 来 海量 的 信息 外 , 它 与 传统 媒体 的 
最 大 区 别 之 一 就 是 它 具 有 和 用 户 的 交互 性 ,使 得 网 站 能 够 为 用 户 制作 许多 个 性 化 的 服务 。 
一 个 具有 精美 的 网 站 设计 ,先进 的 技术 应 用 和 丰富 的 内 容 更 新 的 网 站 ,不 见得 访问 量 就 一 
定 能 够 上 升 。 如 果 能 够 在 此 基础 上 ,重视 用 户 信 息 的 反馈 ,及 时 与 用 户 交流 沟通, 这样 给 
用 户 的 感觉 会 更 具有 亲和力 ,也 更 有 利于 提高 网 站 的 “回头 率 "。 如 果 用 户 发 现 他 的 意见 
或 建议 被 网 站 采纳 ,或 者 感觉 到 网 站 对 他 的 关注 ,就 不 但 会 经 常 光 顾 网 站 ,甚至 可 能 会 成 
为 网 站 的 义务 宣传 员 。 网 站 维护 与 反馈 工作 主要 体现 在 以 下 这 些 方面 。 

(1) 用 户 留言 。 

建立 了 留言 板 就 要 经 常 查看 ,在 留言 板 中 留言 的 用 户 一 般 都 是 对 网 站 感 兴趣 的 用 户 ， 
大 多 客户 会 在 这 里 留 下 对 网 站 的 意见 、 建 议 , 尤 其 是 一 些 无 法 显示 的 网 页 错误 等 ,提醒 管 
理 者 及 时 纠正 .解决 ,有 的 客户 会 对 网 页 外 观 , 他 所 需求 的 信息 内 容 及 更 新 时 间 等 提出 自 
己 的 要 求 ,这 对 网 站 的 日 后 更 新 、 升 级 都 是 值得 借鉴 的 资料 。 

制作 好 留言 簿 后 要 经 常 维护 .收集 意见 。 因 为 一 般 访问 者 对 站 点 有 什么 意见 ,通常 都 
会 在 第 一 时 间 看 看 站 点 哪里 有 留言 短 , 然 后 就 在 那里 记录 ,期 望 网 站 管理 员 能 提供 其 想 要 
的 内 容 , 或 提供 相关 的 服务 。 所 以 必须 对 别人 提出 的 问题 进行 分 析 总 结 。 一 方面 要 以 尽 
可 能 快 的 速度 进行 答复 , 另 一 方面 也 要 记录 下 来 进行 切实 的 改进 。 这 样 可 以 从 中 收集 到 
很 多 信息 ,获得 很 多 商机 。 

(2) 用 户 电子 邮件 。 

一 般 情况 下 ,网 站 在 首页 上 都 会 留 下 与 网 站 主人 联系 的 方式 ,这 样 会 方便 客户 与 网 站 
联系 。 对 于 用 户 的 来 信 应 该 及 时 回复 ,有 些 用 户 会 在 信件 中 提出 他 们 自己 的 要 求 和 问题 ， 
管理 者 应 该 做 出 认真 的 解答 。 重 视 每 一 封 来 信 , 争 取 每 一 个 回头 客 ,这 就 像 做 生意 一 样 ， 
回头 客 对 访问 量 的 增加 很 重要 。 如 果 长 时 间 对 用 户 的 信件 置之不理 ,就 会 失去 一 批 难得 
的 回头 客 。 网 站 逐渐 做 大 后 ,可 以 设 专人 管理 ,对 于 固定 格式 信件 可 设置 自动 回复 。 

所 有 的 企业 网 站 都 有 自己 的 联系 页 面 ,通常 是 管理 者 的 电子 邮件 地 址 。 经 常会 有 一 
些 信息 发 到 邮箱 中 ,对 访问 者 的 邮件 要 及 时 答复 。 最 好 是 在 邮件 服务 器 上 设置 一 个 自动 
回复 的 功能 ,这 样 能 够 使 访问 者 对 站 点 的 服务 有 一 种 安全 感 和 责任 感 ,然后 再 对 用 户 的 问 
题 进行 细致 的 解答 。 

(3) 电子 邮件 列表 。 

电子 邮件 列表 是 很 多 企业 网 站 上 都 有 的 .对 电子 邮件 进行 维护 也 很 重要 。 一 方面 要 
保证 发 送 的 频率 , 另 一 方面 要 保证 邮件 的 内 容 , 要 有 新 意 .而 且 最 好 能 与 收集 的 意见 相 结 
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合 。 总 之 了 解 和 关心 网 站 的 访问 者 越 多 ,就 越 有 利于 站 点 的 发 展 。 

(4) BBS。 

如 果 网 站 有 BBS 论坛 ,同样 应 该 重视 在 这 里 发 布 的 文章 。 因 为 BBS 空间 的 自由 度 较 
大 ,除了 要 注意 有 用 的 信息 ,更 应 该 注意 要 及 时 删除 包含 不 健康 反动 有 恶劣 影响 、 漫 骂 
他 人 及 发 布 垃圾 广告 等 类 型 的 文章 ,以 保证 网 站 健康 清洁 的 形象 。 

BBS 是 一 个 自由 的 天 地 ,作为 企业 网 站 可 以 在 其 上 自由 地 讨论 技术 问题 ,而 对 于 
BBS 的 实时 监控 尤为 重要 。 例 如 对 一 些 色情 和 反动 的 言论 要 马上 删除 ,否则 一 来 会 影响 
网 站 的 形象 ,二 来 可 能 会 引起 大 麻烦 。 从 另 一 个 角度 讲 ,BBS 中 也 可 能 会 出 现 一 些 乱 七 
八 糟 的 广告 ,对 此 要 及 时 删除 ,否则 影响 BBS 的 性 质 , 不 会 再 吸引 浏览 者 。 有 时 甚至 会 出 
现 一 些 竞争 对 手 的 广告 或 旗 毁 企业 形象 的 言论 ,更 需要 及 时 删除 。 同 时 要 多 收集 一 些 相 
关 资 料 在 BBS 中 发 表 , 以 保证 BBS 园地 的 学 术 性 质 。 

(5) 投票 .调查 问卷 。 

每 隔 一 定 的 时 间 ,还 可 以 在 网 站 上 发 布 一 些 投票 .调查 问卷 之 类 的 活动 ,以 吸引 用 户 
的 参与 。 不 管 是 针对 哪 一 方面 的 调查 ,都 应 该 精心 设计 ,例如 , 抓 住 一 些 社会 热点 话题 ,从 
独特 的 视角 反 向 提出 问题 ,使 问题 具有 较 强 的 针对 性 和 个 性 .引起 用 户 的 兴趣 。 

企业 站 点 上 经 常会 有 一 些 投票 调查 的 程序 ,用 来 了 解 访 问 者 的 喜好 或 意见 。 一 方面 
要 对 已 调查 的 数据 进行 分 析 , 另 一 方面 也 可 以 经 常 变换 调查 的 内 容 。 但 对 于 调查 内 容 的 
设置 要 有 针对 性 ,不 要 搞 一 些 空 泛 的 问题 。 也 可 以 针对 某 个 热点 投票 ,以 吸引 别人 关注 

4. 定期 更 新 .动态 维 护 

管理 维护 网 站 容易 产生 的 误区 就 是 以 为 保证 网 站 的 正常 运转 就 万 事 大 吉 了 。 其 实 不 
然 ,应 该 不 断 地 宣传 以 吸引 新 用 户 的 光临 ,更 重要 的 工作 是 要 不 断 地 维护 ,经常 地 更 新 ,以 
保证 老 顾 客 的 需求 ,这 才 是 一 个 网 站 的 立身 之 本 。 一 个 总 给 人 以 新 意 , 具 有 不 断 充 实 的 新 
内 容 和 信息 的 网 站 , 才 是 真正 具有 生命 力 的 网 站 。 

网 站 的 更 新 应 该 在 处 理 客户 信息 的 基础 上 ,根据 统计 分 析 的 结果 ,及 时 摸 清 大 多 数 用 
户 的 兴趣 所 在 ,有 针对 性 地 进行 更 新 。 

要 有 规律 地 更 新 维护 网 站 ,定时 维护 ,这 样 既 节省 时 间 ,而 且 会 减轻 劳动 强度 ,因为 有 
规律 ,更 方便 网 友 们 查阅 和 使 用 。 

当 我 们 有 了 创意 要 及 时 维护 ,珍惜 难得 的 灵感 和 创造 力 。 对 用 户 、 网 友 提 出 的 较 集 中 
的 问题 ,及 时 做 出 反映 。 做 到 动态 维护 .定期 更 新 。 

更 新 的 内 容 要 充实 、 及 时 ,不 要 让 访问 者 感觉 到 是 在 应 付 。 这 就 需要 平时 丰富 的 积累 
和 广泛 地 搜集 材料 。 

进行 更 新 维护 的 具体 工作 就 是 进行 网 页 文件 的 上 传 . 下 载 ,更改 和 删除 等 。 

在 这 里 还 需要 注意 的 一 个 问题 就 是 对 历史 内 容 的 存放 处 理 。 网 络 服务 器 的 空间 毕竟 
有 限 , 尤 其 是 提供 申请 租用 网 页 空间 的 网 站 对 网 页 空间 大 小 都 有 限制 ,对 于 网 站 上 有 保存 
价值 的 信息 数据 应 该 及 时 处 理 。 

5. 修正 网 页 错误 


这 也 是 网 站 管理 维护 的 基本 工作 ,有 了 前 面 的 这 些 基 础 ,就 应 该 能 找到 网 站 中 有 问 
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题 \ 有 错误 的 网 页 了 。 

修正 网 页 的 错误 ,首先 包括 网 页 上 的 技术 性 错误 。 这些 错 误 包括 网 页 的 链接 错误 、 网 
页 无 法 正常 显示 、 无 法 看 到 图 片 . 无 法 听 到 背景 音乐 、 过 大 的 网 页 、 过 大 过 小 的 字体 ,前 景 
色 、 背 景色 色差 过 小 以 至 于 看 不 清 等 。 这 些 错误 需要 回 到 设计 和 制作 网 页 时 使 用 的 工具 
中 进行 再 次 的 调整 编辑 ,然后 再 上 传 到 服务 器 。 

还 有 就 是 网 页 中 的 内 容错 误 。 除 了 用 户 指出 的 错误 外 ,管理 者 也 应 该 经 常 关注 自己 
的 网 站 ,从 中 查找 错误 ,尤其 是 一 些 介绍 技术 或 技术 性 产品 的 网 站 ,以 免 给 用 户 不 好 的 
印象 。 

6. 网 上 推广 与 营销 不 可 缺少 

要 想 让 更 多 的 人 知道 自己 的 网 站 ,就 要 在 网 上 进行 推广 。 网 上 推广 的 手段 很 多 ,大 多 
数 是 免费 的 。 主 要 的 推广 手段 包括 搜索 引擎 注册 、 注 册 加 入 行业 网 站 、 邮 件 宣传 .论坛 贸 
言 . 新 闻 组 ,友情 连接 、 互 换 广告 条 及 B2B 站 点 发 布 信息 等 。 除 了 网 上 推广 外 ,还 有 很 多 
网 上 与 网 下 结合 的 渠道 ,例如 可 将 网 址 和 企业 的 商标 一 起 使 用 ,通过 产品 、 信 短 、 名 片 和 公 
司 资料 等 途径 可 以 很 快 地 将 网 站 告知 用 户 , 以 方便 用 户 从 网 上 了 解 企业 的 最 新 动态 。 

7. 不 断 完善 网 站 系统 ,提供 更 好 的 服务 

初 建 网 站 一 般 投 入 较 少 ,功能 也 不 是 很 强 。 随 着 业务 的 发 展 ,网 站 的 功能 也 应 该 不 断 
完善 以 满足 用 户 的 需要 。 此 时 使 用 集成 度 高 的 电子 商务 应 用 系统 可 以 更 好 地 实现 网 上 业 
务 的 管理 和 发 展 ,从 而 将 企业 的 电子 商务 带 向 更 高 的 阶段 ,取得 更 大 的 成 绩 。 

8. 网 站 备份 

网 站 维护 最 后 要 注意 的 就 是 对 网 站 文件 的 备份 了 。 如 果 服 务 器 发 生 了 灾难 ,网 站 就 
很 有 可 能 被 彻底 毁坏 ,因此 时 常备 份 网 站 文件 是 非常 重要 的 。 


7.2.3 选择 站 点 维护 工具 


如 果 决 定 自己 完成 站 点 维护 ,可 以 利用 许多 有 用 的 工具 。 要 改变 HTML, 当 然 需要 
某 种 HTML 编辑 器 ,许多 HTML 编辑 器 提供 站 点 维护 的 专用 工具 ,如 链接 和 HTML 验 
证 器 ,因此 也 要 确保 选择 这 些 工 具 。 另 外 ,不 要 忘记 与 主机 公司 取得 联系 ,因为 许多 公司 
提供 主机 软件 包 的 维护 工具 。 下 面 将 简单 介绍 两 种 主要 的 用 户 定制 维护 工具 。 

1. 改进 工具 

在 改进 的 维护 工具 中 ,服务 包括 从 链接 验证 器 到 信息 量 分 析 器 的 全 部 范围 ,例如 ， 
Netscape 公司 的 Web SiteGarage’s Tune Up 服务 有 以 下 特点 。 

(1) 浏览 器 兼容 性 检查 。 检 查 页 面 是 否 能 在 不 同 的 浏览 器 版 本 中 显示 。 

(2) 搜索 引擎 可 读 性 。 确 认 页 面包 括 正确 的 META 标记 。 

(3) 下 载 时 间 检 查 。 报 告 页 面 下 载 速度 的 快慢 程度 。 

(4) 链接 检查 。 找 出 过 时 的 链接 。 

(5) 链接 普及 性 检查 。 确 定 有 多 少 页 面 用 流行 的 搜索 引擎 链接 到 站 点 。 

(6) 拼写 检查 。 指 出 拼 错 的 词 。 
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(7) HTML 检查 。 检 查 页 面 是 否 符合 W3C HTML 的 规范 。 

许多 其 他 公司 现在 也 提供 类 似 的 服务 ,下 面 列 出 了 一 些 受 欢迎 的 公司 。 

。 Doctor HTMLCwww2. imagiware. com/RxHTML/) 

。 LinkAlarm(www. linkalarm. com) 

» Net Mechanic(www. netmechanic. com) 

迄今 为 止 ,我 们 列 出 的 这 些 工具 都 是 在 线 运 行 的 .用户 可 以 购买 几 个 质量 好 的 产品 安 
装 到 自己 的 系统 中 。 一 般 来 说 ,Web 管理 员 更 愿意 使 用 下 面 的 这 些 产 品 来 管理 和 维护 他 
们 自己 的 站 点 。 

。 CyberSpyder 的 Aman Software(www. cyberspyder. com) 

。 Linkbot 的 Watchfire(www. watchfire. com/products/linkbot. htm) 

。 WebMaster 的 Coast Software Inc. (www. coast. com) 

。 WebTrends 的 WebTrends 公司 (www. webtrends. com) 

2. 服务 器 监视 

一 种 较 新 的 联机 维护 工具 是 第 三 方 (third-party) 的 服务 器 监视 。 有些 公 司 ( 例 如 @ 
Watch 或 Server Rat 等 ) 对 Web 服务 器 进行 监视 ,定期 检查 用 户 服务 器 ,以 确保 所 有 的 工 
作 都 在 正常 地 进行 。 如 果 他 们 检查 出 故障 ,会 在 5 分 钟 之 内 通知 用 户 。 

这 种 服务 最 大 的 优点 是 监控 器 本 身 是 独立 的 ,因为 监控 公司 不 是 主机 公司 ,用 户 更 希 
望 能 把 服务 中 的 失误 及 时 地 通知 他 们 。 
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以 与 我 们 联系 ， 我们 将 向 使 用 本 教材 进行 教学 的 教师 免费 赠送 电子 教案 (素材), 希望 有 
助 于 教学 活动 的 开展 。 相 关 信 息 请 拨打 电话 010-62776969 或 发 送 电 子 邮 件 至 
jsjijc@tup.tsinghua.edu.cn 咨询 ， 也 可 以 到 清华 大 学 出 版 社 主页 (http://www.tup.com.cn 或 
http://www.tup.tsinghua.edu.cn) 上 查询 。 


